0

我正在尝试使用这种技术执行服务器端方法:

Javascript Ajax 函数

function storeLocal(brand, type) {
    $.ajax({
        type: "POST",
        contentType: "application/json; charset=utf-8",
        data: "{brand:'" + brand + "'}",
        url: "Jquery Site.Master/storeLocal",
        datatype: "json",
        success: OnSuccess(brand),
    });
}

function OnSuccess(brand) {
    alert(brand);
}

C#方法:

[WebMethod]
public static object storeLocal(string brand)
{
    HttpContext.Current.Session.Add("Brand", brand);
}

要执行的代码行是:

<li>
    <a class="strong" onclick="storeLocal('petzl','harness')" href="About.aspx">Harnesses</a>
</li>

但它没有正确执行我的代码中是否有任何特殊错误?我使用这种方法的原因是因为我想要一个小项目的动态菜单,并希望在会话中存储用户在会话中选择的特定“li”,以便我可以在重定向页面中加载内容。非常感谢阿德里安

4

4 回答 4

1

您的方法中没有返回可能是问题,您的方法应该如下所示

[WebMethod]
 public static object storeLocal(string brand)
 {
     HttpContext.Current.Session.Add("Brand", brand);
     return "value" +brand;
 }
于 2012-09-12T07:32:30.547 回答
0

根据您的ajax请求,我可以看到几个错误:

  1. url参数值不是正确的 URL 。
  2. 你没有OnSuccess正确分配你的方法。

尝试将其更改为:

function storeLocal(brand, type) { 
    $.ajax({ 
        type: "POST", 
        contentType: "application/json; charset=utf-8", 
        data: "{brand:'" + brand + "'}", 
        url: "ProperSiteUrl/storeLocal", 
        datatype: "json", 
        success: OnSuccess, 
    }); 
} 

而且您不会从您的storeLocal网络方法中返回任何内容。尝试将其更改为:

 [WebMethod]  
 public static object storeLocal(string brand)  
 {  
     HttpContext.Current.Session.Add("Brand", brand);  
     return ...;
 } 

此外,您将 JSON 发送到服务器,但是,对于单个参数,您可能会发现将其作为键/值对发送更容易,例如

...
data: "brand=" + brand
...
于 2012-09-12T07:37:54.477 回答
0

我不确定您的代码是否正确!你已经给出了 href 和 onclick 并且页面可能会在 onclick ajax 事件完成之前导航到 about.aspx。

尝试删除 href 或将 onclick 事件放入 href='javascript:storelocal()' 并从 webmethod 返回值。

在 webmethod 中保留一个断点并查看内容是否正在传递给 webmethod。

于 2012-09-12T07:39:37.923 回答
0

网址和成功看起来不太好。

1 - 在 ajax 调用中,您没有将参数传递给成功函数。它将由 c# 中指定的 webmethod 返回一些东西。您在数据属性中指定数据,并将其用作传递给 webmethod 的参数。

2 - 您不能使用母版页调用 webmethod,它必须在您正在工作的页面中指定。aspx 文件不是主文件。该页面继承自 master,但它不是 master。是具有母版页文件规范的页面。

试试这个来识别错误,看看返回了什么

error: function (error) {
    alert(JSON.stringify(error));
}
于 2012-09-12T08:52:40.710 回答