【问题标题】:passing an array to json.stringify将数组传递给 json.stringify
【发布时间】:2012-01-20 15:26:41
【问题描述】:

我正在尝试将一个数组传递给 json.stringify 但返回的值是空的。

JSON.stringify({ json: data }) // returns `{"json":[]}`

这里是数据的内容:

data[from] = "bfleming@test.com"
data[to] = "test@test.com"
data[message] = "testmessage"

jquery:

function SubmitUserInformation($group) {
    var data = {};
    data = ArrayPush($group);
    $.ajax({
        type: "POST",
        url: "http://www.mlaglobal.com/components/handlers/FormRequestHandler.aspx/EmailFormRequestHandler",
        data: JSON.stringify({ json: data }),
        dataType: 'json',
        contentType: "application/json; charset=utf-8",
        cache: false,
        success: function (msg) {
            if (msg) {
                $('emailForm-content').hide();
                $('emailForm-thankyou').show();
            }
        },
        error: function (msg) {
            form.data("validator").invalidate(msg);
        }
    });
}

function ArrayPush($group) {
    var arr = new Array();
    $group.find('input[type=text],textarea').each(function () {
        arr[$(this).attr('id')] = $(this).val();
    });
    return arr;
}

【问题讨论】:

    标签: javascript jquery json


    【解决方案1】:
    data = ArrayPush($group);
    

    正在将data 重新分配为一个数组,因此您的所有 expando 属性都不会被字符串化。

    在你的 ArrayPush 方法中,改变

    var arr = new Array();
    

    var obj = { };
    

    【讨论】:

      【解决方案2】:

      arr 应该在ArrayPush 方法中声明为一个对象,因为你没有像数组一样使用它。同样在函数内部,您可以只使用this.idthis.value,您不必创建jQuery 对象。试试这个

      function ArrayPush($group) {
          var arr = {};
          $group.find('input[type=text],textarea').each(function () {
              arr[this.id] = this.value;
          });
          return arr;
      }
      

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 2012-08-08
        • 1970-01-01
        • 2020-08-05
        • 2020-07-28
        • 2014-01-14
        • 1970-01-01
        • 2013-02-22
        • 1970-01-01
        相关资源
        最近更新 更多