Я бы обычно использовал JSON в качестве моего типа данных AJAX. JSON (нотация объектов JavaScript) работает так же, как XML, но использует примерно на 70% меньше данных . Вам также будет легче разобраться в вашем javascript. Вам не нужно инициализировать объекты даты / числа из xml!
{ "people": [
{ "firstName": "Brett", "lastName":"McLaughlin", "email": "brett@newInstance.com" },
{ "firstName": "Jason", "lastName":"Hunter", "email": "jason@servlets.com" },
{ "firstName": "Elliotte", "lastName":"Harold", "email": "elharo@macfaq.com" }
]}
Спасибо IBM за пример
<people>
<person>
<firstName>Brett</firstName>
<lastName>McLaughlin</lastName>
<email>brett@newInstance.com</email >
</person>
<person>
<firstName>Jason</firstName>
<lastName>Hunter</lastName>
<email>jason@servlets.com</email >
</person>
<person>
<firstName>Elliotte</firstName>
<lastName>Harold</lastName>
<email>elharo@macfaq.com</email >
</person>
</people >
Я обнаружил, что инфраструктура MVC JSON имеет некоторые недостатки в отношении сериализации, десериализации и игнорирования атрибутов членов. Я нашел проект Json.NET на codeplex. он заполняется, чтобы заполнить все пробелы в функциональности, которые не покрывает MVC JSON.
Итак, в вашем контроллере, я использую Json.NET, обратите внимание, что выводом является ContentResult и не имеет представление
public ContentResult ProcessRequestAction(string Email, string Password)
{
Product product = new Product();
product.Name = "Apple";
product.Expiry = new DateTime(2008, 12, 28);
product.Price = 3.99M;
product.Sizes = new string[] { "Small", "Medium", "Large" };
return Content(JavaScriptConvert.SerializeObject(product));
}
Типичный код JQuery, для запроса JSON
$.ajax({
type: "POST", /* GET OR POST */
url: "JSON_MVC_URL_HERE", /* your url here */
dataType: "json", /* json or xml */
data: null, /* JSON CODE HERE TO SET GET OR POST BACK PARAMS */
success: function(data){
alert(data.Name); /* Gets Name Element */
alert(data.Expiry); /* Gets Expiry Element */
alert(data.Price); /* Gets Price Element */
jQuery.each(data.Sizes, function() { /* Get Each Size */
alert(this);
});
}
});
$. GetJSON также работает, но отсутствует запрос http типа POST / GET