JSON stringify отсутствует в JQuery 1.4.1? - PullRequest
74 голосов
/ 17 февраля 2010

Очевидно, jQuery имеет возможность декодировать данный объект или строку в объект JSON.Тем не менее, у меня есть объект JS, который мне нужно отправить обратно на сервер, и я не нахожу в jQuery утилиту, которая бы обернула функцию JSON.stringify ().Эта функция есть в Chrome, Safari 4, FF3.6 и IE8, но не доступна в более ранних браузерах.Я могу использовать его изначально в браузерах, которые его поддерживают, но в противном случае вынужден прибегнуть к использованию JSON-скриптов Крокфорда.

Есть ли какая-то встроенная в jQuery, которая обрабатывает кодирование и декодирование JSON, которое заменяет собойсценарии Крокфорда?

Ответы [ 6 ]

30 голосов
/ 17 февраля 2010

Вы можете проверить это: http://www.json.org/js.html

26 голосов
/ 18 октября 2010

Вы можете использовать «Библиотеку закрытия» (Google) для создания кросс-браузерного JSON-кодировщика / декодера.

Просто зайдите на http://closure -compiler.appspot.com /

и вставьте следующее в текстовое поле, затем нажмите «Компиляция»:

// ==ClosureCompiler==
// @compilation_level ADVANCED_OPTIMIZATIONS
// @output_file_name default.js
// @use_closure_library true
// ==/ClosureCompiler==

goog.require('goog.json');
if (!window['JSON']) window['JSON']={};
if (typeof window['JSON']['stringify'] !== 'function') window['JSON']['stringify']=goog.json.serialize;
if (typeof window['JSON']['parse'] !== 'function') window['JSON']['parse']=goog.json.parse;
14 голосов
/ 17 февраля 2010

jQuery может декодировать строки JSON с помощью jQuery.parseJSON().

Для кодирования я знаю только плагин: jquery-json

3 голосов
/ 13 марта 2012

jQuery не нуждается в этой функциональности внутри и, следовательно, не предоставляет удобный метод для этого.

JSON.stringify () - это стандартный и рекомендуемый способ кодирования объекта в строковое представление JSON этого объекта. Это метод нативного объекта JSON во многих браузерах, и рекомендуется использовать json2.js (https://github.com/douglascrockford/JSON-js), чтобы обеспечить запасной вариант.

2 голосов
/ 30 марта 2012

Чтобы построить ответ Stewe, компилятор закрытия с включенным Advanced предоставляет сценарий, который загрязняет глобальное пространство имен связкой переменных из одной буквы. Итак, я просто обернул его в вызов анонимной функции следующим образом:

(function() { function g(a){var b=typeof a;if("object"==b)if(a){if(a instanceof Array)return"array";if(a instanceof Object)return b;var c=Object.prototype.toString.call(a);if("[object Window]"==c)return"object";if("[object Array]"==c||"number"==typeof a.length&&"undefined"!=typeof a.splice&&"undefined"!=typeof a.propertyIsEnumerable&&!a.propertyIsEnumerable("splice"))return"array";if("[object Function]"==c||"undefined"!=typeof a.call&&"undefined"!=typeof a.propertyIsEnumerable&&!a.propertyIsEnumerable("call"))return"function"}else return"null"; else if("function"==b&&"undefined"==typeof a.call)return"object";return b};function h(a){a=""+a;if(/^\s*$/.test(a)?0:/^[\],:{}\s\u2028\u2029]*$/.test(a.replace(/\\["\\\/bfnrtu]/g,"@").replace(/"[^"\\\n\r\u2028\u2029\x00-\x08\x10-\x1f\x80-\x9f]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g,"]").replace(/(?:^|:|,)(?:[\s\u2028\u2029]*\[)+/g,"")))try{return eval("("+a+")")}catch(b){}throw Error("Invalid JSON string: "+a);}function i(a,b){var c=[];j(new k(b),a,c);return c.join("")}function k(a){this.a=a} function j(a,b,c){switch(typeof b){case "string":l(b,c);break;case "number":c.push(isFinite(b)&&!isNaN(b)?b:"null");break;case "boolean":c.push(b);break;case "undefined":c.push("null");break;case "object":if(null==b){c.push("null");break}if("array"==g(b)){var f=b.length;c.push("[");for(var d="",e=0;e<f;e++)c.push(d),d=b[e],j(a,a.a?a.a.call(b,""+e,d):d,c),d=",";c.push("]");break}c.push("{");f="";for(e in b)Object.prototype.hasOwnProperty.call(b,e)&&(d=b[e],"function"!=typeof d&&(c.push(f),l(e,c),c.push(":"), j(a,a.a?a.a.call(b,e,d):d,c),f=","));c.push("}");break;case "function":break;default:throw Error("Unknown type: "+typeof b);}}var m={'"':'\\"',"\\":"\\\\","/":"\\/","\u0008":"\\b","\u000c":"\\f","\n":"\\n","\r":"\\r","\t":"\\t","\x0B":"\\u000b"},n=/\uffff/.test("\uffff")?/[\\\"\x00-\x1f\x7f-\uffff]/g:/[\\\"\x00-\x1f\x7f-\xff]/g; function l(a,b){b.push('"',a.replace(n,function(a){if(a in m)return m[a];var b=a.charCodeAt(0),d="\\u";16>b?d+="000":256>b?d+="00":4096>b&&(d+="0");return m[a]=d+b.toString(16)}),'"')};window.JSON||(window.JSON={});"function"!==typeof window.JSON.stringify&&(window.JSON.stringify=i);"function"!==typeof window.JSON.parse&&(window.JSON.parse=h); })();

Теперь вы можете позвонить:

var JSONString = JSON.stringify({name: 'value'});

1 голос
/ 14 марта 2012

Часто при использовании jQuery функция JSON.stringify () не требуется. Возьмем, к примеру, общий случай использования ajax для отправки данных javascript на сервер. Jquery имеет встроенные функции для обработки этого:

$.post("test.php", { name: "John", time: "2pm" } );
$.post("test.php", { 'choices[]': ["Jon", "Susan"] });
$.getJSON("test.js", { name: "John", time: "2pm" }, function(json) {
    alert("JSON Data: " + json.users[3].name);
});

Во всех приведенных выше примерах отправленные данные javascript автоматически сериализуются jQuery.

Сериализация в этих случаях отличается от JSON.Stringify (), вместо этого данные сериализуются в HTML-строку запроса (см .: http://en.wikipedia.org/wiki/Query_string#Structure).

Однако эта форма сериализации подходит для большинства (но не для всех) приложений

...