js动态产生对象push进数组,发现数组所有元素(element or object)一样

版权声明:需要转载的话,请先联系我哦! https://blog.csdn.net/wwt20180911/article/details/83178246

原因:对象是同一个对象,动态创建对象时,不断对对象赋值,push进数组,数组[obj,obj,obj],所有的obj值相同,因而导致数组中都是同一个对象 talk is cheap,show you the code

错误写法:

//处理个人基本情况信息
        var family = $("#familyList").find("tr");
        var familyList=[];
        for (var i=0;i<family.length;i++) {
            var tdArr = family.eq(i).find("td");//
            var name = tdArr.eq(0).find('input').val();//姓名
            var relationship = tdArr.eq(1).find('input').val();//与本人关系
            var workOrganization = tdArr.eq(2).find('input').val();//工作单位及职务
            var tel = tdArr.eq(3).find('input').val();//联系电话
            if(tel){
                if(!(/^1[3456789]\d{9}$/.test(tel))){
                    alert("家庭信息手机号码有误,请重填~")
                    return false
                }
            }
            var address = tdArr.eq(4).find('input').val();//联系地址
            var obj = {
                name: name,
                relationship: relationship,
                workOrganization: workOrganization,
                tel:tel,
                address:address,
            };
        }
       familyList.push(obj);
        console.log(familyList)

正确写法

 //处理个人基本情况信息
        var family = $("#familyList").find("tr");
        var familyList=[];
        for (var i=0;i<family.length;i++) {
            var tdArr = family.eq(i).find("td");//
            var name = tdArr.eq(0).find('input').val();//姓名
            var relationship = tdArr.eq(1).find('input').val();//与本人关系
            var workOrganization = tdArr.eq(2).find('input').val();//工作单位及职务
            var tel = tdArr.eq(3).find('input').val();//联系电话
            if(tel){
                if(!(/^1[3456789]\d{9}$/.test(tel))){
                    alert("家庭信息手机号码有误,请重填~")
                    return false
                }
            }
            var address = tdArr.eq(4).find('input').val();//联系地址
            var obj = {
                name: name,
                relationship: relationship,
                workOrganization: workOrganization,
                tel:tel,
                address:address,
            };
            familyList.push(obj);
        }
        console.log(familyList)

作者:涛兄
来源:CSDN
原文:https://blog.csdn.net/wwt20180911/article/details/83178246
版权声明:本文为博主原创文章,转载请附上博文链接!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值