微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在Jquery中序列化数组?

如何准备这个数组为$.ajax提交?
这里图像返回[“val1”,“val2”],但是在我使用$.param(图像)后,我得到undefined = undefined& undefined = undefined
$('#rem_images').click(function(){
         var images = new Array();
        $('.images_set_image input:checked').each(function(i){
            images[i] = $(this).val();
        });
        alert($.param(images));
        return false;

一般来说,想法是检查页面上要删除的图像,然后按钮点击循环,通过所有图像检查,并将序列化数组提交到ajax到PHP脚本.

解决方法

你没有以正确的格式传递数组到$.param.从 jQuery.param docs

If the object passed is in an Array,it must be an array of objects in the format returned by 07001.

数组应该是由名称/值对组成的对象数组.你看到undefined = undefined& undefined = undefined因为“val1”.name,“val1”.value,“val2”.name和“val2”.value都是未定义的.它应该看起来像这样:

[{name: 'name1',value: 'val1'},{name: 'name2',value: 'val2'}]

所以你可以这样构造数组(假设你的复选框有一个name属性):

$('#rem_images').click(function(){
    var images = [];
    $('.images_set_image input:checked').each(function(){
        var $this = $(this);
        images.push({name: $this.attr('name'),value: $this.val()});
    });
    alert($.param(images));
    return false;
});

尽管如此,即使是使用.map()(因为功能编程是好东西):

$('#rem_images').click(function(){
    var images = $('.images_set_image input:checked').map(function(){
        var $this = $(this);
        return {name: $this.attr('name'),value: $this.val()};
    }).get();
    alert($.param(images));
    return false;
});

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐