0

我继承了一些查询 webmethod 并返回字符串的 ASP 2.0 webforms 代码,它的简化版本是

代码背后

<System.Web.Services.WebMethod()> _
Public Function StockLevel() as String
    return "120"
End Sub

.aspx 页面

function GetStockLevel() {
$.ajax({
    type: 'POST',
    url: 'Stock.aspx/StockLevel',
    // data: '{ }',
    contentType: 'application/json; charset=utf-8',
    dataType: 'text',
    success: function (data) {
    alert(data);
    }
});
}

该页面上有一个 asp 标签控件,例如 asp:Label id="stockLabel" runat="server"

目前,当我尝试修改 StockLevel 函数以将标签文本设置为 120 时,它将字符串 120 返回到 jquery 调用中并显示警报,例如

stockLabel.Text = "120"

我得到了智能感知,但它似乎没有更新页面上的值,我想这是由于 AJAX 的性质(在这种情况下,我应该只使用 ajax 调用的返回值来设置标签的值。 ),此时可能未加载控件或存在范围问题。这个对吗?我想知道为什么会发生这种情况,这是我应该期望的正确行为还是我做错了什么并且标签应该更新为正确的值?

任何指示或建议都会很棒。

4

2 回答 2

1

我相信 ASP 标签会呈现为跨度,您应该能够像这样更改它:

success: function (data) {
    $("#<%=stockLabel.ClientID %>").text(data);
}

至于从 web 方法访问页面控件,您是不允许的。这篇文章比我做得更好:Access ASP.NET control from static [WebMethod] (JS ajax call)

于 2013-04-23T20:54:59.537 回答
1

当您通过 AJAX 调用 web 方法时,您不能这样做。

如果您通过 AJAX 进行调用,您将无法访问您的 Web 表单控件,因为您实际上并没有请求该页面,您只是在调用该方法。

相反,您应该使用 jQuery 找到标签并通过 Javascript 更新它:

function GetStockLevel() {
$.ajax({
    type: 'POST',
    url: 'Stock.aspx/StockLevel',
    // data: '{ }',
    contentType: 'application/json; charset=utf-8',
    dataType: 'text',
    success: function (data) {
        $("#<%=stockLabel.ClientID %>").text(data);  // this only works if the javascript is in your .aspx-file
    }
});
}

如果脚本不在您的 .aspx 中,您需要找到另一种在客户端上查找节点的方法(例如,通过使用特定类)。

于 2013-04-23T20:57:25.610 回答