请教一个js对象[]访问的问题?

发布于 2022-09-05 22:49:49 字数 1191 浏览 20 评论 0

我所理解的对象访问方式有两种:
object.property
object['property']

但是下边代码的parState 是一个对象,不理解的是这一句parState[$(parLabel[i]).attr('data-label')] = true;

data-label 获取的是一个id数字

<span class="status icons-checked checkNum parLabel" check-num="{{itemList.length}}" data-label="{{supplierId}}"></span>
function getLabelState(){
    var totalState = [];
    var parState = {};
    var childState = {};
    var parLabel = $('.parLabel');
    var childLabel = $('.childLabel');
    for(var i=0;i<parLabel.length;i++){
        if($(parLabel[i]).hasClass('icons-checked')){
            parState[$(parLabel[i]).attr('data-label')] = true;
        }else{
            parState[$(parLabel[i]).attr('data-label')] = false;
        }
    }
    for(var j=0;j<childLabel.length;j++){
        if($(childLabel[j]).hasClass('icons-checked')){
            childState[$(childLabel[j]).attr('data-label')] = true;
        }else{
            childState[$(childLabel[j]).attr('data-label')] = false;
        }
    }
    totalState.push(parState);
    totalState.push(childState);
    return totalState;
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

何以畏孤独 2022-09-12 22:49:49

clipboard.png

有什么疑问吗?就是一个赋值吧

一桥轻雨一伞开 2022-09-12 22:49:49

$(parLabel[i]).attr('data-label') 就是取到每个span 的data-label属性值

然后作为key放到 parState中 value 就是你的那个判断不是true就是false

无声静候 2022-09-12 22:49:49

[]里面是动态的不是很正常么。。
最后都会转化为字符串在对象中找寻对应的key访问

风情万种。 2022-09-12 22:49:49

数字做key没有问题啊……
当键为数字的时候,obj[key]的key是数字还是字符串,效果是一样的。
另外就是明明用jq,为什么循环搞那么复杂

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文