Pergunta

Como você retornar um objeto JSON serializada para o lado do cliente usando ASP.NET MVC através de uma chamada AJAX?

Foi útil?

Solução

A partir do controlador que você pode simplesmente retornar um JsonResult:

public ActionResult MyAction()
{
    ... // Populate myObject
    return new JsonResult{ Data = myObject };
}

A forma da chamada Ajax vai depender de qual biblioteca você está usando, é claro. Usando jQuery seria algo como:

$.getJSON("/controllerName/MyAction", callbackFunction);

onde o callbackFunction leva um parâmetro que é o dados do pedido XHR.

Outras dicas

Dependendo de suas preferências de sintaxe, o seguinte também funciona:

public ActionResult MyAction()
{
    return Json(new {Data = myObject});
}

Este é o bloco pequeno de código para apenas entender, como podemos usar JsonResults em Controladores MVC.

   public JsonResult ASD()
    {
    string aaa = "Hi There is a sample Json";
    return Json(aaa);
    }

Você também pode System.Web.Script.Serialization; como abaixo

using System.Web.Script.Serialization;

public ActionResult MyAction(string myParam)
{

    return  new JavaScriptSerializer().Serialize(myObject);
}

Ajax

$.ajax({
    type: 'POST',
    url: '@Url.Action("MyAction","MyMethod")',
    dataType: 'json',
    contentType: "application/json; charset=utf-8",
    data: JSON.stringify({ "myParam": "your data" }),
    success: function(data)
    {
        console.log(data)
    },
    error: function (request, status, error) {

    }
});

Se você precisa enviar JSON em resposta a um GET, você precisa permitir explicitamente o comportamento usando JsonRequestBehavior.AllowGet.

public JsonResult Foo()
{
    return Json("Secrets", JsonRequestBehavior.AllowGet);
}
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top