首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用jQuery设置一个值,将JSON发布到ASP.Net Web 2服务

使用jQuery设置一个值,将JSON发布到ASP.Net Web 2服务
EN

Stack Overflow用户
提问于 2014-05-07 16:56:59
回答 1查看 324关注 0票数 0

我有一个看似简单的jQuery ajax函数,可以将整数数组发布到web服务中:

代码语言:javascript
复制
$(document).ready(function() {
    $("#testButton").click(function() {
        $.ajax({
            type: "POST",
            url: "api/setactivedemodatasetids/",
            data: [1, 2, 8, 9],
            success: function() {},
            dataType: "application/json"
        });
    });
});

和一个简单的ASP.Net Web 2控制器来接收发布的数据:

代码语言:javascript
复制
[Route("api/setactivedemodatasetids/")]
[AcceptVerbs("POST")]
public void SetActiveDemoDataSetIds(int[] ids)
{
    var db = new DataClassesDataContext();
    // Do stuff
    db.SubmitChanges();
}

当我在控制器中设置断点时,参数ids的值为

代码语言:javascript
复制
{int[0]}

为什么?为什么它不是一个由4个整数1、2、8和9组成的数组?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-05-07 17:47:18

设置dataType: "json"contentType: "application/json; charset=utf-8"和数据:JSON.stringify([1, 2, 8, 9] )

https://api.jquery.com/jQuery.ajax/

我想这段代码能解决你的问题

代码语言:javascript
复制
$("#testButton").click(function () {
                    $.ajax({
                        type: "POST",
                        contentType: "application/json; charset=utf-8",
                        dataType: "json",
                        url: "api/setactivedemodatasetids/",
                        data: JSON.stringify([1, 2, 8, 9]),
                        success: function () { },
                        error: function (xhr, ajaxOptions, thrownError) {
                            alert(xhr.status);
                            //alert(xhr.responseText);
                            alert(thrownError);
                        }

                    });
                });
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23523846

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档