Где / когда мы используем JSON? - PullRequest
15 голосов
/ 22 июля 2009

Подскажите, пожалуйста, в чем польза JSON (в Javascript и PHP). когда нам нужен метод JSON.

Я прочитал по следующей ссылке, но не получил никакой информации о реализации JSON ни в одном проекте.

http://www.json.org/js.html

Ответы [ 9 ]

21 голосов
/ 22 июля 2009

JSON - это легкий формат обмена данными (думайте, что это XML на диете). Практически в любом месте, где вы можете использовать XML для сериализации данных, вы можете использовать вместо этого JSON.

8 голосов
/ 22 июля 2009

Несмотря на название, одним из основных применений формата JSON является AJAX веб-разработка (хотя, конечно, не единственная). Он часто предпочитается традиционному XML из-за легкого синтаксиса.

4 голосов
/ 22 июля 2009

JSON - это формат данных, используемый при передаче данных. Он используется главным образом в вызовах Javascript AJAX.

Структура JSON - это просто имя: значение в квадратных скобках. Благодаря своей компактности и простоте, это лучшая структура для передачи относительно небольших наборов данных и вещей, которые можно сгруппировать в пары имя: значение.

Например:

Преобразование Ajax prototype.js для преобразования и получения данных JSON:

my_prototype_class = Class.create();  
my_prototype_class.prototype = {
    initialize: function() { 
        this.myarray = new Array();
        //do initialization
    },      
    my_function: function(direction){  
        new Ajax.Request('/my/url.php', 
            {     
                method: 'post',
                parameters: {   name: value,
                                myarray_data: this.myarray.toJSON()  },   
                onSuccess: function(transport) { 
                    var response = transport.responseText.evalJSON();
                    //handle response   
                },
                onFailure: function(){
                    //handle failure
                }    
            });  
    }
} 
Event.observe(window, "load", function(){new my_prototype_class();}, false);

И используя PHP, вы обработаете запрос примерно так:

function my_php_handler()
{   
    #parse POST data
    $name = $_POST["name"]; 
    $myarray_data = $_POST["myarray_data"];

    #transform the data in some way

    #return encoded string
    echo json_encode($results);
}

Что-то вроде:

[{"myarray": [], "name": value}]

будет передано в запросе / ответе http. Данные в этом формате называются JSON.

3 голосов
/ 22 июля 2009

JSON - отличный формат для передачи данных между Javascript и PHP. Я чаще всего использую сообщения о состоянии.

Вот некоторый Javascript для выполнения Ajax-запроса к небольшому PHP-скрипту.

    new Ajax.Request('dostuff.php', {
        method:  'get',
        parameters:  {'param1':  'this is param 1'},
        onSuccess:  function(response, jsonHeader){
          if(jsonHeader['status'] == 'Success'){
            //Everything is OK, do stuff
          }else{
            alert(jsonHeader['status']);
          }
        },
        onFailure:  function(){
            alert('Fail!');
        }
    });

Тогда на стороне PHP вы можете получить что-то вроде этого:

    $jsonHeader = array();

    if($_REQUEST['param1'])
    {
      echo '<p>You passed ' . $_REQUEST['param1'] . '</p>';
      $jsonHeader['status'] = 'Success';
    }else
    {
      $jsonHeader['status'] = 'Failed because the request was invalid';
    }

    if(is_array($jsonHeader) and sizeof($jsonHeader) > 0)
    {
      header('X-JSON: (' . json_encode($jsonHeader) . ')');
    }

Замечательно, что Prototype автоматически декодирует заголовок X-JSON, который создает PHP.

Конечным результатом является то, что аргумент jsonHeader метода onSuccess в Javascript автоматически преобразуется в массив, который содержит те же данные, что и массив $ jsonHeader в PHP

3 голосов
/ 22 июля 2009

JSON - это просто формат данных. Если вам нужно хранить или переносить данные, которые не сложнее, чем вложенная серия пар имя-значение, значения которых поддерживаются стандартом JSON, тогда JSON может быть правильным форматом данных для вашего проекта.

Если ваш проект нуждался в хранении данных / транспортировке;)

2 голосов
/ 22 июля 2009

Все остальные ответы хороши, но, возможно, самое простое объяснение для вашего конкретного случая (JavaScript + PHP): JSON - это самый простой способ перевести объект JavaScript в ассоциативный массив или объект PHP (и наоборот). Versa) .

Взгляните на json_encode () и json_decode () с точки зрения PHP. Что касается JavaScript, простой eval () - это самый простой (но наименее безопасный!) Способ получить объект из строки JSON, но ваша библиотека, безусловно, будет иметь функции, которые позаботятся об этом за вас, и если вы ориентируетесь на новые браузеры, вы можете использовать объект ECMAScript 5 JSON .

2 голосов
/ 22 июля 2009

Я бы предложил использовать JSON, если вам нужно манипулировать извлеченными данными (т. Е. С помощью вызова Ajax в вашем браузере) с помощью кода JavaScript. В таком случае JSON очень удобен, так как вы можете напрямую загрузить его в свой JavaScript и использовать его (следовательно, Java Script Object Notation => JSON). Это называется десериализацией строки JSON в объектах JavaScript. Это может быть сделано с помощью eval (), что, как я читал, создает некоторые проблемы с безопасностью, поэтому следует использовать некоторый сериализатор JSON (*).

Как описано на странице , которую вы упомянули, у вас есть какая-то строка JSON, такая как

{"bindings": [
        {"ircEvent": "PRIVMSG", "method": "newURI", "regex": "^http://.*"},
        {"ircEvent": "PRIVMSG", "method": "deleteURI", "regex": "^delete.*"},
        {"ircEvent": "PRIVMSG", "method": "randomURI", "regex": "^random.*"}
    ]
}

, который отправляется по сети, инициируемой некоторыми вызовами Ajax на клиенте, где затем вызывается обратный вызов, например (например, в .Net)

function onSuccess(result){
  var myObj = Sys.Serialization.JavaScriptSerializer.deserialize(result, false);
  myObj.bindings[0].ircEvent...
}

Преимущество заключается в простой (де) сериализации вместе при использовании JavaScript, в основном при веб-разработке с Ajax. В противном случае я бы не использовал JSON, а полагался бы на XML, поскольку для настольных приложений существуют действительно мощные библиотеки синтаксического анализа.

2 голосов
/ 22 июля 2009

JSON - это относительно легкий формат обмена данными (по крайней мере, по сравнению с XML или HTML), который наиболее полезен при обмене небольшими объемами данных между веб-клиентом и веб-сервером / службой.

Тем не менее, это не лучший выбор (хотя и намного лучше, чем XML) для обмена большими списками данных из-за накладных расходов на каждую обмениваемую строку.

1 голос
/ 22 июля 2009

JSON в основном используется как легкая и удобочитаемая альтернатива XML в веб-приложениях AJAX.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...