Wykonywanie prostego wywołania Ajax do kontrolera w asp.net mvc


109

Próbuję rozpocząć korzystanie z wywołań ASP.NET MVC Ajax.

Kontroler:

public class AjaxTestController : Controller
{
    //
    // GET: /AjaxTest/
    public ActionResult Index()
    {
        return View();
    }

    public ActionResult FirstAjax()
    {
        return Json("chamara", JsonRequestBehavior.AllowGet);
    }   
}

Widok:

<head runat="server">
    <title>FirstAjax</title>
    <script src="http://code.jquery.com/jquery-1.9.1.js"></script>
    <script src="http://ajax.googleapis.com/ajax/libs/jquery/2.0.0/jquery.min.js"></script>
    <script type="text/javascript">
        $(document).ready(function () {
            var serviceURL = '/AjaxTest/FirstAjax';

            $.ajax({
                type: "POST",
                url: serviceURL,
                data: param = "",
                contentType: "application/json; charset=utf-8",
                dataType: "json",
                success: successFunc,
                error: errorFunc
            });

            function successFunc(data, status) {     
                alert(data);
            }

            function errorFunc() {
                alert('error');
            }
        });
    </script>
</head>

Muszę tylko wydrukować alert z metodą kontrolera zwracającą dane. Powyższy kod wydaje mi się po prostu "chamara". Alert nie działa.

AKTUALIZACJA

Zmodyfikowałem kontroler jak poniżej i zaczyna działać. Nie mam jasnego pojęcia, dlaczego teraz działa. Niech ktoś wyjaśni. Parametr "a" nie jest powiązany Dodałem go, ponieważ nie mogę dodać dwóch metod o tej samej nazwie metody i parametrach. Myślę, że to może nie być rozwiązanie, ale działa

public class AjaxTestController : Controller
    {
        //
        // GET: /AjaxTest/
        [HttpGet]
        public ActionResult FirstAjax()
        {
            return View();
        }

        [HttpPost]
        public ActionResult FirstAjax(string a)
        {
            return Json("chamara", JsonRequestBehavior.AllowGet);
        }
    }

zwraca sformatowany ciąg json {"name":"chamara"}. następnie spróbuj czytać jakodata['name']
Raab

1
Usuń drugą bibliotekę jQuery z widoku. Twój kod powinien działać bez zmian. Myślę, że mógł wystąpić błąd skryptu i uniemożliwić wyświetlenie alertu.
Terence

Odpowiedzi:


23

Po zakończeniu aktualizacji

  1. jego pierwsze wywołanie akcji FirstAjax z domyślnym żądaniem HttpGet i renderowanie pustego widoku HTML. (Wcześniej tego nie miałeś)
  2. później, po załadowaniu elementów DOM tego widoku, wywołanie Ajax zostaje uruchomione i wyświetla alert.

Wcześniej zwracałeś tylko JSON do przeglądarki bez renderowania kodu HTML. Teraz ma wyrenderowany widok HTML, w którym może pobrać dane JSON.

Nie możesz bezpośrednio renderować JSON jako zwykłych danych, a nie HTML.


52

Usuń atrybut data, ponieważ nie jesteś POSTINGniczym dla serwera (Twój kontroler nie oczekuje żadnych parametrów).

W swojej metodzie AJAX możesz używać Razori używać @Url.Actionzamiast statycznego ciągu:

$.ajax({
    url: '@Url.Action("FirstAjax", "AjaxTest")',
    contentType: "application/json; charset=utf-8",
    dataType: "json",
    success: successFunc,
    error: errorFunc
});

Z Twojej aktualizacji:

$.ajax({
    type: "POST",
    url: '@Url.Action("FirstAjax", "AjaxTest")',
    contentType: "application/json; charset=utf-8",
    data: { a: "testing" },
    dataType: "json",
    success: function() { alert('Success'); },
    error: errorFunc
});

3
@chamara - przepraszam, usuń HttpPost (nie wysyłasz niczego na serwer, więc byłby to zbędny atrybut), a kontroler nie zostałby trafiony. Usuń także „type: POST” w funkcji AJAX, ponieważ cię zasiałem.
Darren

18

Użyj narzędzia Razor, aby dynamicznie zmienić adres URL, wywołując akcję w ten sposób:

$.ajax({
    type: "POST",
    url: '@Url.Action("ActionName", "ControllerName")',
    contentType: "application/json; charset=utf-8",
    data: { data: "yourdata" },
    dataType: "json",
    success: function(recData) { alert('Success'); },
    error: function() { alert('A error'); }
});

Parametry dla Url.Action są wsteczne w tej odpowiedzi, jest to Url.Action (actionName, controllerName)
xd6_

1
Nie jestem fanem tego, zachęca to do łączenia widoku i javascript, ale uh, nazwa użytkownika się sprawdza?
Halter

@Halter UX znacznie się poprawia, gdy nie zmuszasz użytkownika do przekierowania przy każdej akcji. Po stronie klienta dzieje się wiele rzeczy, o które serwer nie powinien dbać.
Kanion Kolob

@KolobCanyon masz 100% racji. Mój komentarz odnosi się bardziej do renderowania adresu URL za pomocą brzytwy w javascript, to ściśle łączy twój javascript z widokiem (cshtml). To dobra odpowiedź, ale aby naprawić ścisłe powiązanie, możesz zrzucić adres URL do atrybutu danych w chstml i przeczytać go w javascript. Przepraszam za zamieszanie!
Halter

5

Po pierwsze, nie ma potrzeby posiadania dwóch różnych wersji bibliotek jquery na jednej stronie, albo „1.9.1”, albo „2.0.0” jest wystarczające, aby wywołać Ajax działało.

Oto kod twojego kontrolera:

    public ActionResult Index()
    {
        return View();
    }

    public ActionResult FirstAjax(string a)
    {
        return Json("chamara", JsonRequestBehavior.AllowGet);
    }   

Oto jak powinien wyglądać Twój widok:

<script src="http://ajax.googleapis.com/ajax/libs/jquery/2.0.0/jquery.min.js"></script>

<script type="text/javascript">
$(document).ready(function () {
    var a = "Test";
    $.ajax({
        url: "../../Home/FirstAjax",
        type: "GET",
        data: { a : a },
        success: function (response) {
            alert(response);
        },
        error: function (response) {
            alert(response);
        }
    });
});
</script>

5

Jeśli potrzebujesz tylko nacisnąć metodę C # w swoim wywołaniu Ajax, wystarczy przekazać dwa typy sprawy i adres URL, jeśli żądanie zostanie odebrane, wystarczy podać tylko adres URL. proszę postępować zgodnie z kodem poniżej, działa dobrze.

Kod C #:

    [HttpGet]
    public ActionResult FirstAjax()
    {
        return Json("chamara", JsonRequestBehavior.AllowGet);
    }   

Kod skryptu Java w przypadku żądania żądania

    $.ajax({
        url: 'home/FirstAjax',
        success: function(responce){ alert(responce.data)},
        error: function(responce){ alert(responce.data)}
    });

Kod skryptu Java w przypadku żądania wysłania, a także [HttpGet] do [HttpPost]

        $.ajax({
            url: 'home/FirstAjax',
            type:'POST',
            success: function(responce){ alert(responce)},
            error: function(responce){ alert(responce)}
        });

Uwaga: Jeśli korzystasz z FirstAjax w tym samym kontrolerze, w którym znajduje się kontroler widoku, nie ma potrzeby podawania nazwy kontrolera w adresie URL. lubićurl: 'FirstAjax',


4

To dla twojego pytania UPDATE.

Ponieważ nie możesz mieć dwóch metod o tej samej nazwie i podpisie, musisz użyć atrybutu ActionName:

AKTUALIZACJA:

[HttpGet]
public ActionResult FirstAjax()
{
    Some Code--Some Code---Some Code
    return View();
}

[HttpPost]
[ActionName("FirstAjax")]
public ActionResult FirstAjaxPost()
{
    Some Code--Some Code---Some Code
    return View();
}

I proszę odnieść się do tego linku, aby uzyskać dalsze informacje o tym, jak metoda staje się działaniem. Bardzo dobre odniesienie.


1

Widok;

 $.ajax({
        type: 'GET',
        cache: false,
        url: '/Login/Method',
        dataType: 'json',
        data: {  },
        error: function () {
        },
        success: function (result) {
            alert("success")
        }
    });

Metoda kontrolera;

 public JsonResult Method()
 {
   return Json(new JsonResult()
      {
         Data = "Result"
      }, JsonRequestBehavior.AllowGet);
 }

0

zamiast url: serviceURL, używać

url: '<%= serviceURL%>',

i czy przekazujesz 2 parametry do successFunc?

function successFunc(data)
 {
   alert(data);
 }

0

Dodaj „JsonValueProviderFactory” w global.asax:

protected void Application_Start()
{
    AreaRegistration.RegisterAllAreas();
    ValueProviderFactories.Factories.Add(new JsonValueProviderFactory());
}

co to jest JsonValueProviderFactory?
Kiquenet,
Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.