问答

getAttribute()提示Cannot set property 'id' of undefined

作者:admin 2021-04-17 我要评论

本人不擅长JS,奈何公司没有前端。遇到问题如题所述,令我迷惑不解的是,同样的代码在IF判断外能获取正确属性值,放到IF判断内就报错。 代码如下: var tempHtml...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

本人不擅长JS,奈何公司没有前端。遇到问题如题所述,令我迷惑不解的是,同样的代码在IF判断外能获取正确属性值,放到IF判断内就报错。
代码如下:

var tempHtml = document.getElementById("templet").querySelectorAll(".itemsp");
var formJson = new Array();
tempHtml.forEach(function (val,key){
    var inputs = val.getElementsByTagName("input");
 for(var i=0;i<inputs.length;i++){
        //console.log(key+":"+inputs[i].getAttribute("type"));
 console.log(val.firstChild.parentElement.getAttribute("id"));
 if(i == 0){
            formJson[key].id = val.firstChild.parentElement.getAttribute("id");
 formJson[key].name = inputs[i].getAttribute("name");
 formJson[key].title = inputs[i].value;
 }else{
            formJson[key].options = {"id":i,"type":inputs[i].getAttribute("data-type"),"name":inputs[i].getAttribute("name"),"title":inputs[i].getAttribute("value")};
 }
    }
    formJson = formJson.toString();
 console.log(formJson);
})

在IF上面的代码获取到了正确的元素属性,IF内同样代码就报错了。
image

###

根据错误,报的是set property,并不是get property,所以可以确认是在formJson[key].id这里的fromJson[key]为undefined,可以先给fromJson[key]赋值

fromJson[key] = {};
fromJson[key].id = ...

当然也可以直接这样

fromJson[key]={
    id: val.firstChild.parentElement.getAttribute("id"),
    name: inputs[i].getAttribute("name"),
    title: inputs[i].value
}

具体不太清楚你的业务逻辑,只是根据你的错误,给出的解决方案,具体你需要根据你的需求去看,另外建议贴代码的时候,格式化一下

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • nginx响应速度很慢

    nginx响应速度很慢

  • 点击选中的多选框,会在已选那一栏显示

    点击选中的多选框,会在已选那一栏显示

  • PHP 多态的理解

    PHP 多态的理解

  • 关于C语言中static的问题

    关于C语言中static的问题

腾讯云代理商
海外云服务器