• [转]js对象中取属性值(.)和[ ]的区别


    原文地址:https://www.jianshu.com/p/6a76530e4f8f

    今天在写js的过程中遇到这么一个问题,取一个对象的属性值,通过obj.keys怎么都取不出来,但是用obj[keys]就可以。(这个是模拟的数据)

    后来通过查资料明白,我这里data.water输出undefined,是因为object使用(.)获取属性值时,这里的water不是使用的变量water,而是直接去data对象中寻找名为water的key,没有找到,所以报undefined。 

    区别:

    相同点:都可以获取到obj的属性值

    不同点:

         1 [ ]运算符可以使用字符串变量的内容作为属性名,点运算符不能

         2 [ ]运算符可以用纯数字作为属性名,点运算符不能

        3 [ ]运算符可以用js关键字和保留字作为属性名,点运算符不能

    eg:

    1 [ ]运算符可以使用字符串变量的内容作为属性名,点运算符不能

        这里由于变量的var声明的变量会导致变量提升,所以会报undefined

    2   [ ]运算符可以用纯数字作为属性名,点运算符不能

    总结:对于一般的常量就使用(.)运算符,对于其他的使用[ ]运算符。

  • 相关阅读:
    linux服务篇
    降智比赛题解
    CF 1437 题解
    ZR 2020普转提七连测day5
    20联赛集训day11 题解
    contest5 题解
    20联赛集训day9 题解
    20联赛集训day8 题解
    contest4 题解
    20联赛集训day7 题解
  • 原文地址:https://www.cnblogs.com/dirgo/p/11796503.html
Copyright © 2020-2023  润新知