web-dev-qa-db-fra.com

Appel de méthode Ajax

J'essaie d'appeler une méthode simple dans mon code derrière l'utilisation de Jquery avec Ajax. Mais je reçois une exception 404 introuvable à chaque fois. Malheureusement, il s'agit d'une solution de formulaires Web. Je n'ai donc pas tous les avantages de MVC :(

Il entre dans la méthode javascript et donne l'alerte mais n'entrera pas dans ma méthode c #. Mon expérience précédente de l'utilisation de cette méthode Jquery est dans un site Web MVC. Est-il compatible avec les sites Webforms?

Mon Javascript est:

$(document).ready(function() {

              $('#btn_<%=UserStuff.tag %>').click(function() {                    

                  var value = $('#<%#Eval("tag") %>Twink').val();
                  something(value);                    
              });
          });


          function something(theval) {

            alert(theval);

              $.ajax({
                  type: "POST",
                  url: "/Default.aspx/MyMethod?something=" + theval,
                  data: "{}",
                  contentType: "application/json; charset=utf-8",
                  dataType: "json",
                  success: function(msg) {
                      alert(msg);
                  }
              });
          }
}

Et mon code C # est:

   public JsonResult MyMethod(string something)
{
    JsonResult ret = new JsonResult();      

    return ret;
}

Merci d'avance.

16
Funky

Votre méthode renvoie JsonResult. Ceci est spécifique à MVC et vous ne pouvez pas l'utiliser dans une application webforms.

Si vous voulez appeler des méthodes dans le code derrière dans une application WebForms classique, vous pouvez utiliser PageMethods :

[WebMethod]
public static string GetDate()
{
    return DateTime.Now.ToString();
}

Et puis pour appeler la méthode:

$.ajax({
    type: 'POST',
    url: 'PageName.aspx/GetDate',
    data: '{ }',
    contentType: 'application/json; charset=utf-8',
    dataType: 'json',
    success: function(msg) {
        // Do something interesting here.
    }
});

Et voici un exemple de travail complet que j'ai écrit pour vous:

<%@ Page Language="C#" %>
<%@ Import Namespace="System.Web.Services" %>
<script type="text/C#" runat="server">
    [WebMethod]
    public static string SayHello(string name)
    {
        return "Hello " + name;
    }
</script>
<!DOCTYPE html>
<html>
<head>
    <title></title>
    <script type="text/javascript" src="/scripts/jquery-1.4.1.js"></script>
    <script type="text/javascript">
        $(function () {
            $.ajax({
                type: 'POST',
                url: 'default.aspx/sayhello',
                data: JSON.stringify({ name: 'John' }),
                contentType: 'application/json; charset=utf-8',
                dataType: 'json',
                success: function (msg) {
                    // Notice that msg.d is used to retrieve the result object
                    alert(msg.d);
                }
            });
        });
    </script>
</head>
<body>
    <form id="Form1" runat="server">

    </form>
</body>
</html>

Les PageMethods ne sont pas limités aux types d'arguments simples. Vous pouvez utiliser n'importe quel type d'entrée et de sortie, il sera automatiquement sérialisé en JSON.

39
Darin Dimitrov