(转-原作者不详)-浅析JavaScript访问对象属性和方法及区别
来源:互联网 发布:ppt图表无法修改数据 编辑:程序博客网 时间:2024/05/22 17:23
属性是一个变量,用来表示一个对象的特征,如颜色、大小、重量等;方法是一个函数,用来表示对象的操作,如奔跑、呼吸、跳跃等。 在JavaScript中通常使用”."运算符来存取对象的属性的值。或者使用[]作为一个关联数组来存取对象的属性。
对象的属性和方法统称为对象的成员。
访问对象的属性
在JavaScript中,可以使用“ . ”和“ [ ] ”来访问对象的属性。
- 使用“ . ”来访问对象属性
语法:
objectName.propertyName
其中,objectName 为对象名称,propertyName为属性名称。
- 使用“ [ ] ”来访问对象属性
语法:
objectName[propertyName]
其中,objectName 为对象名称,propertyName为属性名称。
访问对象的方法
在JavaScript中,只能使用“ . ”来访问对象的方法。
语法:
objectName.methodName()
其中,objectName 为对象名称,methodName() 为函数名称。
例创建一个Person类:
function Person() { this.name=" 张三 "; // 定义一个属性 name this.sex=" 男 "; // 定义一个属性 sex this.age=22; // 定义一个属性 age this.say=function(){ // 定义一个方法 say() return "嗨!大家好,我的名字是 " + this.name + " ,性别是 " + this.sex + ",今年 " + this.age +"岁!"; }}var zhangsan=new Person();alert("姓名:"+zhangsan.name); // 使用“.”来访问对象属性alert("性别:"+zhangsan.sex);alert("年龄:"+zhangsan["age"]); // 使用“[ ]”来访问对象属性alert(zhangsan.say); // 使用“.”来访问对象方法
PS:浅析对象访问属性的"."和"[]"方法区别
在JavaScript中通常使用”.”运算符来存取对象的属性的值。或者使用[]作为一个关联数组来存取对象的属性。但是这两种方式有什么区别了?
例如,读取object中的property属性值:
object.property object['property']
以上两种方式都可以实现属性的存取。
1.语法方面的区别
点表示法的对象的属性名是标识符,而后者的属性名则是一个字符串。
2.灵活性方面的区别
在JavaScript编写程序中,可以为对象创建任意数目的属性。但使用”.“运算符来存取一个对象的属性时,属性名是用标识符表示的。而在JavaScript程序中,标识符必须被逐字地输入,它们不是一种数据类型,因此程序不能对其操作。也就是说,标识符是静态的,在程序中必须对其进行硬编码。
而使用数组[]表示法来存取一个对象的属性时,属性名是用字符串表示的。字符串是JavaScript的一种数据类型,因此可以在程序运行中操作并创建它们。
3.性能方面区别
数组[]表示法在存取属性值时会进行表达式运行。而点表示法是直接存取属性值,理论上执行效率会比数组表示法高。性能方面其实可以忽略。
某些场景必须用到数组表示法来动态存取属性值,这个是点表示法无法做到的。
总的来说,这两种方法区别上不大,都有对应的使用场景。点表示法一般作为静态对象使用时来存取属性。而数组表示法在动态存取属性时就非常有用。
- (转-原作者不详)-浅析JavaScript访问对象属性和方法及区别
- 浅析JavaScript访问对象属性和方法及区别
- 浅析JavaScript访问对象属性和方法及区别
- 浅析JavaScript访问对象属性和方法及区别
- 访问javascript对象的属性和方法
- javascript对象及内置对象属性和方法
- javascript对象属性及方法
- JavaScript中的高级特性及特别对象、属性和方法
- javascript中的高级特性及特别对象、属性和方法
- JavaScript中的高级特性及特别对象、属性和方法
- Javascript中的高级特性及特别对象、属性和方法
- JavaScript中for和for-in的区别;访问对象的属性.和[]的区别
- JavaScript对象的创建和属性访问
- 野狗的辩证法(转)(原作者不详)
- javascript 访问对象属性
- Javascript 访问对象属性
- JavaScript内置对象属性及方法大全
- JavaScript内置对象属性及方法大全
- direction和unicode-bidi
- 在centos 7中搭建lamp平台
- stringstream的用法
- MyISAM 和InnoDB
- (GIS可视化)热点分析原理及实现
- (转-原作者不详)-浅析JavaScript访问对象属性和方法及区别
- poj 2299 树状数组(离散化)求逆序数
- 数据流重定向-导出训练日志
- string insert()函数的用法
- hdu 2319
- 判断文件是否为二进制
- numpy找出array中的最大值,最小值
- Hibernate 未联网情况下不能根据dtd解析hbm.xml
- F