5

我有一个文本框和旁边的按钮。我想通过 Jquery ajax 调用将文本框的内容发送到 webmethod 并取回相同的大写值并在警报中显示。到目前为止,我有这个代码,但它不工作。

JAVASCRIPT:

function CallWM()
    {          

        var name = $('#name').val();         


        RealCallWM(name);


    }
    function RealCallWM(name) {

        $.ajax({
            url: 'Register.aspx/UpperWM',
            type: 'POST',
            contentType: 'application/json; charset=utf-8',
            data: { name: JSON.stringify(name) },
            success: OnSuccess(response),
            error: function (response) {
                alert(response.responseText);
            }
        })
    };

HTML:

  Name:    <input id="name" type="text" /> 
<input id="Button1" type="button" value="button" onclick="CallWM();"/></div>
    </form>

网络方法:

 [WebMethod]
        public static string UpperWM(string name )
        {
            var msg=name.ToUpper();
            return (msg);
        }
4

2 回答 2

4

代替:

data: '{name: ' + name + '}',

和:

data: { name: JSON.stringify(name) },

以确保正确编码。现在,您正在发送以下有效负载:

{name:'some value'}

这显然是一个无效的 JSON 有效负载。在 JSON 中,所有内容都应该用双引号引起来:

{"name":"some value"}

这就是为什么您绝对不应该使用一些字符串连接手动构建 JSON 而是使用内置方法 ( JSON.stringify) 的原因。

旁注:我不确定是否存在failure$.ajax方法可以理解的回调。所以:

$.ajax({
    url: 'Register.aspx/UpperWM',
    type: 'POST',
    contentType: 'application/json; charset=utf-8',
    data: { name: JSON.stringify(name) },
    success: OnSuccess(response),
    error: function (response) {                        
        alert(response.responseText);
    }
});

另请注意,在您的错误回调中,我已删除该response.d属性,就好像您的 Web 方法中存在异常一样,服务器可能根本不会返回任何 JSON。

于 2013-07-15T13:50:05.280 回答
2

根据您的评论,我了解您的问题尚未解决,所以试试这个

    function RealCallWM(name) {
        $.ajax({
            type: "POST",
            url: "Default.aspx/UpperWM",
            data: JSON.stringify({ name: $('#name').val() }),
            contentType: "application/json; charset=utf-8",
            dataType: "json",
            async: true,
            success: function (data, status) {
                console.log("CallWM");
                alert(data.d);
            },               
            failure: function (data) {
                alert(data.d);
            },
            error: function (data) {
                alert(data.d);
            }
        });
    }
于 2013-07-15T14:46:42.403 回答