Тип математики с плавающей запятой, которая может быть реализована на цифровом компьютере, обязательно использует приближение реальных чисел и операций над ними. (Стандартная версия стандартная работает до более чем пятидесяти страниц документации и имеет комитет для рассмотрения ее ошибок и дальнейшего уточнения.)
Это приближение представляет собой смесь приближений разного типа, каждый из которых можно либо игнорировать, либо тщательно учитывать из-за его конкретного способа отклонения от точности. Это также включает в себя ряд явных исключительных случаев как на уровне аппаратного обеспечения, так и на уровне программного обеспечения, которое большинство людей прогуливает прямо мимо, делая вид, что не замечает.
Если вам нужна бесконечная точность (например, вместо числа π одного из его более коротких резервных копий), вы должны написать или использовать символическую математическую программу.
Но если вы в порядке с идеей о том, что иногда математика с плавающей запятой нечеткая по значению и логике и ошибки могут быстро накапливаться, и вы можете написать свои требования и тесты для этого, тогда ваш код может часто проходить с помощью того, что находится в вашем FPU.
Поскольку вы не указали ни тип содержимого запроса, ни правильный запрос JSON. Вот правильный способ отправки запроса JSON:
var arr = { City: 'Moscow', Age: 25 };
$.ajax({
url: 'Ajax.ashx',
type: 'POST',
data: JSON.stringify(arr),
contentType: 'application/json; charset=utf-8',
dataType: 'json',
async: false,
success: function(msg) {
alert(msg);
}
});
Замечания:
JSON.stringify
для преобразования объекта javascript в строку JSON который является родным и встроенным в современные браузеры. Если вы хотите поддерживать старые браузеры, вам может потребоваться включить json2.js contentType
, чтобы указать серверу цель отправка запроса JSON dataType: 'json'
используется для типа ответа, который вы ожидаете от сервера. jQuery достаточно умен, чтобы угадать его из заголовка ответа сервера Content-Type
. Поэтому, если у вас есть веб-сервер, который уважает более или менее HTTP-протокол и отвечает на Content-Type: application/json
на ваш запрос, jQuery будет автоматически анализировать ответ в javascript-объекте в обратном вызове success
, так что вам не нужно указывать Свойство dataType
. Осторожно:
arr
, не является массивом. Это объект javascript со свойствами (City
и Age
). Массивы обозначаются символом []
в javascript. Например, [{ City: 'Moscow', Age: 25 }, { City: 'Paris', Age: 30 }]
представляет собой массив из двух объектов. Я написал небольшую удобную функцию для размещения JSON.
$.postJSON = function(url, data, success, args) {
args = $.extend({
url: url,
type: 'POST',
data: JSON.stringify(data),
contentType: 'application/json; charset=utf-8',
dataType: 'json',
async: true,
success: success
}, args);
return $.ajax(args);
};
$.postJSON('test/url', data, function(result) {
console.log('result', result);
});
Вам нужно установить правильный тип контента и подкрепить свой объект.
var arr = {City:'Moscow', Age:25};
$.ajax({
url: "Ajax.ashx",
type: "POST",
data: JSON.stringify(arr),
dataType: 'json',
async: false,
contentType: 'application/json; charset=utf-8',
success: function(msg) {
alert(msg);
}
});
Поскольку по умолчанию jQuery сериализует объекты, переданные как параметр data
, на $.ajax
. Он использует $.param
для преобразования данных в строку запроса.
Из документов jQuery для $.ajax
:
[аргумент
blockquote>data
] преобразуется в строку запроса, если уже не строкаЕсли вы хотите отправить JSON, вам придется ее кодировать самостоятельно:
data: JSON.stringify(arr);
Обратите внимание, что
JSON.stringify
присутствует только в современных браузерах. Для устаревшей поддержки загляните в json2.js
Он сериализуется так, чтобы URI мог считывать пары значений имени в запросе POST по умолчанию. Вы можете попробовать установить processData: false в свой список параметров. Не уверен, что это поможет.