После прочтения различных решений я хотел бы добавить, что причина, по которой эти решения работают, заключается в том, чтобы полагаться на концепцию цепочки областей видимости. Это способ, которым JavaScript разрешает переменную во время выполнения.
var
и ее arguments
. window
. В начальном code:
funcs = {};
for (var i = 0; i < 3; i++) {
funcs[i] = function inner() { // function inner's scope contains nothing
console.log("My value: " + i);
};
}
console.log(window.i) // test value 'i', print 3
Когда выполнение funcs
выполняется, цепочка областей видимости будет function inner -> global
. Поскольку переменную i
невозможно найти в function inner
(ни объявлено с использованием var
, ни передано как аргументы), она продолжает поиск, пока значение i
не будет найдено в глобальной области видимости window.i
.
Обернув его во внешнюю функцию, либо явно определите вспомогательную функцию, как harto , либо использовали анонимную функцию, например Bjorn :
funcs = {};
function outer(i) { // function outer's scope contains 'i'
return function inner() { // function inner, closure created
console.log("My value: " + i);
};
}
for (var i = 0; i < 3; i++) {
funcs[i] = outer(i);
}
console.log(window.i) // print 3 still
Когда выполняется funcs
, теперь цепочка видимости будет function inner -> function outer
. На этот раз i
можно найти в области внешней функции, которая выполняется 3 раза в цикле for, каждый раз имеет значение i
правильно. Он не будет использовать значение window.i
, когда внутреннее исполнение выполнено.
Более подробно можно найти здесь . В него входит общая ошибка при создании замыкания в цикле, как то, что мы имеем здесь, а также почему мы нуждаемся в закрытии и рассмотрении эффективности.
В то время как вы, как правило, без него, можете и должны устанавливать заголовок Content-Type:
<?PHP
$data = /** whatever you're serializing **/;
header('Content-Type: application/json');
echo json_encode($data);
Если я не использую определенную структуру, я обычно разрешаю некоторые параметры запроса изменить поведение вывода. Полезно, как правило, для быстрого устранения неполадок, чтобы не отправлять заголовок или иногда print_r полезную нагрузку данных для глазного яблока (хотя в большинстве случаев это не обязательно).
Полный кусок приятного и понятного PHP-кода, возвращающего JSON:
$option = $_GET['option'];
if ( $option == 1 ) {
$data = [ 'a', 'b', 'c' ];
// will encode to JSON array: ["a","b","c"]
// accessed as example in JavaScript like: result[1] (returns "b")
} else {
$data = [ 'name' => 'God', 'age' => -1 ];
// will encode to JSON object: {"name":"God","age":-1}
// accessed as example in JavaScript like: result.name or result['name'] (returns "God")
}
header('Content-type: application/json');
echo json_encode( $data );
Вы можете использовать эту небольшую библиотеку PHP . Он отправляет заголовки и дает вам возможность использовать его легко.
Он выглядит так:
<?php
// Include the json class
include('includes/json.php');
// Then create the PHP-Json Object to suits your needs
// Set a variable ; var name = {}
$Json = new json('var', 'name');
// Fire a callback ; callback({});
$Json = new json('callback', 'name');
// Just send a raw JSON ; {}
$Json = new json();
// Build data
$object = new stdClass();
$object->test = 'OK';
$arraytest = array('1','2','3');
$jsonOnly = '{"Hello" : "darling"}';
// Add some content
$Json->add('width', '565px');
$Json->add('You are logged IN');
$Json->add('An_Object', $object);
$Json->add("An_Array",$arraytest);
$Json->add("A_Json",$jsonOnly);
// Finally, send the JSON.
$Json->send();
?>
Если вы запрашиваете базу данных и нуждаетесь в результирующем наборе в формате JSON, это можно сделать следующим образом:
<?php
$db = mysqli_connect("localhost","root","","mylogs");
//MSG
$query = "SELECT * FROM logs LIMIT 20";
$result = mysqli_query($db, $query);
//Add all records to an array
$rows = array();
while($row = $result->fetch_array()){
$rows[] = $row;
}
//Return result to jTable
$qryResult = array();
$qryResult['logs'] = $rows;
echo json_encode($qryResult);
mysqli_close($db);
?>
Для получения справки при анализе результата с помощью jQuery посмотрите на этот учебник .
Это простой PHP-скрипт для возврата мужской и пользовательской идентификаторов, поскольку значение json будет любым случайным значением, когда вы вызываете скрипт json.php.
Надеемся на эту помощь благодаря
<?php
header("Content-type: text/json");
$myObj=new \stdClass();
$myObj->user_id = rand(0, 10);
$myObj->male = rand(0, 5);
$myObj->female = rand(0, 5);
$myJSON = json_encode($myObj);
echo $myJSON;
?>
Установите тип содержимого с помощью header('Content-type: application/json');
, а затем эхо-данные.
Ответ на ваш вопрос здесь ,
Он говорит.
Тип мультимедиа MIME для текста JSON - application / json.
blockquote>, поэтому, если вы установите заголовок этого типа и выведете строку JSON, она должна работать.
Также полезно установить защиту доступа - просто замените * доменом, который вы хотите получить.
<?php
header('Access-Control-Allow-Origin: *');
header('Content-type: application/json');
$response = array();
$response[0] = array(
'id' => '1',
'value1'=> 'value1',
'value2'=> 'value2'
);
echo json_encode($response);
?>
Здесь больше примеров: как обходить Access-Control-Allow-Origin?
Если вам нужно получить json из php, отправляющего специальную информацию, вы можете добавить это header('Content-Type: application/json');
, прежде чем печатать любую другую вещь. Итак, вы можете распечатать custome echo '{"monto": "'.$monto[0]->valor.'","moneda":"'.$moneda[0]->nombre.'","simbolo":"'.$moneda[0]->simbolo.'"}';
Простым способом форматирования объектов вашего домена в JSON является использование сериализатора Маршала . Затем передайте данные в json_encode
и отправьте правильный заголовок Content-Type для ваших нужд. Если вы используете фреймворк вроде Symfony, вам не нужно заботиться о настройке заголовков вручную. Там вы можете использовать JsonResponse .
Например, правильный Content-Type для работы с Javascript будет application/javascript
.
Или, если вам нужно поддержка некоторых довольно старых браузеров самым безопасным будет text/javascript
.
Для всех других целей, таких как мобильное приложение, используйте application/json
как Content-Type.
Вот небольшой пример :
<?php
...
$userCollection = [$user1, $user2, $user3];
$data = Marshal::serializeCollectionCallable(function (User $user) {
return [
'username' => $user->getUsername(),
'email' => $user->getEmail(),
'birthday' => $user->getBirthday()->format('Y-m-d'),
'followers => count($user->getFollowers()),
];
}, $userCollection);
header('Content-Type: application/json');
echo json_encode($data);
Да, вам нужно использовать эхо для вывода вывода. Mimetype: application / json
Да, просто установите соответствующий HTTP-заголовок, эхо результат, а затем выйдите из сценария.
Попробуйте json_encode , чтобы закодировать данные и установить тип содержимого с помощью header('Content-type: application/json');
.
Как было сказано выше:
header('Content-Type: application/json');
выполнит задание. но имейте в виду, что:
В соответствии с руководством в json_encode
метод может возвращать нестроку (false):
Возвращает строку с кодировкой JSON при успешном выполнении или
blockquote>FALSE
при ошибке.Когда это произойдет,
echo json_encode($data)
выведет пустую строку, которая недействительна JSON .
json_encode
будет например, fail (и returnfalse
), если его аргумент содержит строку не UTF-8.Это условие ошибки должно быть записано в PHP, например, следующим образом:
<?php header("Content-Type: application/json"); // Collect what you need in the $data variable. $json = json_encode($data); if ($json === false) { // Avoid echo of empty string (which is invalid JSON), and // JSONify the error message instead: $json = json_encode(array("jsonError", json_last_error_msg())); if ($json === false) { // This should not happen, but we go all the way now: $json = '{"jsonError": "unknown"}'; } // Set HTTP response status code to: 500 - Internal Server Error http_response_code(500); } echo $json; ?>
Тогда конечный вывод должен, конечно, знать, что наличие jsonError указывает на состояние ошибки, которое должно обрабатываться соответствующим образом.
В режиме производства может быть лучше отправить клиенту только общий статус ошибки и записать более конкретные сообщения об ошибках для последующего расследования.
Подробнее о проблемах с ошибками JSON в Документация PHP .