m0_71681226 2022-10-25 11:51 采纳率: 100%
浏览 69
已结题

js用splice更新数组失败。

js用splice更新数组失败。
数组:

var list = [{ "Id": '0', "FirstName": "Stark", "LastName": "Bill", "DateOfBirth": "2000/10/11", "Gender": "Male", "PrimaryInsurance": "Medicare", "Address": "ddadsdasd", "ContactNumber": "1338872818738", "NextOfKin": "weqe" },
    { "Id": '1', "FirstName": "Shown", "LastName": "Jenny", "DateOfBirth": "2000/10/11", "Gender": "Male", "PrimaryInsurance": "Medicare", "Address": "ddadsdasd", "ContactNumber": "1338872818738", "NextOfKin": "weqe" },
    { "Id": '2', "FirstName": "Geogrge", "LastName": "Hash", "DateOfBirth": "2000/10/11", "Gender": "Male", "PrimaryInsurance": "Medicare", "Address": "ddadsdasd", "ContactNumber": "1338872818738", "NextOfKin": "weqe" },
    { "Id": '3', "FirstName": "Intwre", "LastName": "zaiwoo", "DateOfBirth": "2000/10/11", "Gender": "Male", "PrimaryInsurance": "Medicare", "Address": "ddadsdasd", "ContactNumber": "1338872818738", "NextOfKin": "weqe" },
    { "Id": '4', "FirstName": "Niko", "LastName": "baby", "DateOfBirth": "2000/10/11", "Gender": "Male", "PrimaryInsurance": "Medicare", "Address": "ddadsdasd", "ContactNumber": "1338872818738", "NextOfKin": "weqe" }];

html:

Insert a patient
Patient ID*:<input type="text" id="insertId" value="">
First name*:<input type="text" id="FirstName" value="">
Last name*:<input type="text" id="LastName" value="">
Date of birth *:<input type="text" id="DateOfBirth" value="">
Gender*:<input type="text" id="Gender" value="">
Primary insurance*:<input type="text" id="PrimaryInsurance" value="">
Address *:<input type="text" id="Address" value="">
Contact number *:<input type="text" id="ContactNumber" value="">
Next of kin:<input type="text" id="NextOfKin" value="">
<input type="button" value="Insert a Patient" onclick="insertPatient();">

js:

function insertById(list, insertId) {
     var insertId=document.getElementById("insertId");
     var FirstName=document.getElementById("FirstName");
     var LastName=document.getElementById("LastName");
     var DateOfBirth=document.getElementById("DateOfBirth");
     var Gender=document.getElementById("Gender");
     var PrimaryInsurance=document.getElementById("PrimaryInsurance");
     var Address=document.getElementById("Address");
     var ContactNumber=document.getElementById("ContactNumber");
     var NextOfKin=document.getElementById("NextOfKin");
    for (var i = 0; i < list.length; i++) {
        if (list[i].Id === deleteId) {
            list.splice(i, 1,{Id: insertId.value,
                FirstName: FirstName.value,
                LastName: LastName.value,
                DateOfBirth: DateOfBirth.value,
                Gender: Gender.value,
                PrimaryInsurance: PrimaryInsurance.value,
                Address: Address.value,
                ContactNumber: ContactNumber.value,
            NextOfKin: NextOfKin.value});
        }
    }
    return list;
}
function insertPatient(){
     var insertId=document.getElementById("insertId");
     var res = insertById(list,insertId.value)
     console.log(res)
     refreshList();
    
}

错误:
点击insert按钮控制台数组刷新了一下但并没有更新数据。

img

请问这个问题该怎么解决

  • 写回答

4条回答 默认 最新

  • CSDN专家-showbo 2022-10-25 12:01
    关注

    不用splice,直接更新对应id记录数组项就行,并且代码缺少deleteId这个变量,改下面即可。

    
            function insertById(list, insertId) {
                var insertId = document.getElementById("insertId");
                var deleteId = insertId.value;//定义变量
                var FirstName = document.getElementById("FirstName");
                var LastName = document.getElementById("LastName");
                var DateOfBirth = document.getElementById("DateOfBirth");
                var Gender = document.getElementById("Gender");
                var PrimaryInsurance = document.getElementById("PrimaryInsurance");
                var Address = document.getElementById("Address");
                var ContactNumber = document.getElementById("ContactNumber");
                var NextOfKin = document.getElementById("NextOfKin");
                for (var i = 0; i < list.length; i++) {
                    console.log(list[i].Id === insertId, deleteId)
                    if (list[i].Id === deleteId) {///直接更新数组项
                        list[i] = {
                            Id: insertId.value,
                            FirstName: FirstName.value,
                            LastName: LastName.value,
                            DateOfBirth: DateOfBirth.value,
                            Gender: Gender.value,
                            PrimaryInsurance: PrimaryInsurance.value,
                            Address: Address.value,
                            ContactNumber: ContactNumber.value,
                            NextOfKin: NextOfKin.value
                        };
                        break;//不需要继续循环
                    }
                }
                return list;
            }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(3条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 10月25日
  • 已采纳回答 10月25日
  • 创建了问题 10月25日

悬赏问题

  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)
  • ¥15 AIC3204的示例代码有吗,想用AIC3204测量血氧,找不到相关的代码。