JavaScript参考手册
Operators
Property Accessors
属性访问器提供了两种方式用于访问一个对象的属性,它们分别是点号和方括号。
语法
object.property
object['property']
描述
我们可以将对象看做是一个关联数组,或映射,字典,哈希表,查找表。这个数组中的键就是这个对象中属性的名称。通常,当我们提及一个对象的属性时,会对属性与方法之间做个对比。然而,属性与方法之间的区别并不大。一个方法就是一个可以被调用的属性而已,例如一个指向Function实例的引用可以作为对象属性的值。
访问对象属性有两种方式:点号表示法和方括号表示法。
点号表示法
get = object.property;
object.property = set;
以上代码中,property
必须是一个有效的 JavaScript 标识符,例如,一串字母数字字符,也包括下划线及美元符号,但不能以数字作为开头。比如,object.$1
是合法的,而 object.1
是无效不合法的。
document.createElement('pre');
在上述代码块中,document
中存在一个名为"createElement"的方法并且被调用了。
如果对数字字面量使用方法,并且数字文字没有指数且没有小数点,请在方法调用之前的点之前留出空格,以防止点被解释为小数点。
77 .toExponential();
// or
77
.toExponential();
// or
(77).toExponential();
// or
77..toExponential();
// or
77.0.toExponential();
// because 77. === 77.0, no ambiguity
方括号表示法
get = object[property_name];
object[property_name] = set;
property_name
是一个字符串。该字符串不一定是一个合法的标识符;它可以是任意值,例如,"1foo","!bar!", 甚至是一个空格。
document['createElement']('pre');
这里的代码的功能跟上一个列子的作用是相同的。
括号之前允许有空格。
document ['createElement']('pre');
属性名
属性名必须是字符串。这意味着非字符串对象不能用来作为一个对象属性的键。任何非字符串对象,包括number,可通过toString方法,类型转换成一个字符串。
var object = {};
object['1'] = 'value';
console.log(object[1]);
上述代码的输出为"value",因为1被类型转换为'1'。
var foo = {unique_prop: 1}, bar = {unique_prop: 2}, object = {};
object[foo] = 'value';
console.log(object[bar]);
上述的代码的输出也是"value",由于对象foo和bar 都会被转成相同的字符串。在SpiderMonkeyJavaScript 引擎中,这个字符串将会是"['object Object']"。
方法绑定
一个方法没有绑定到对象上,那就意味着这个方法是不起作用的。特别要注意的是,在一个方法中this对象并不是固定的,例如,this不需要指向包含当前方法的对象。this可通过函数调用被传递过去的值所替换。详见方法绑定。
注意eval
JavaScript新手在使用eval时会犯错,在那些可通过括号表示法替换的场景下。例如,下面的语法经常在很多代码中找到。
x = eval('document.forms.form_name.elements.' + strFormControl + '.value');
eval
的性能较差,在任何时候都应该避免使用。而且,此时strFormControl
必须是一个合法的标识符, 这在一些names、IDs表单控件中并不是必要的。所以,最好是使用括号来代替:
x = document.forms['form_name'].elements[strFormControl].value;
规范
Specification |
Status |
Comment |
---|---|---|
ECMAScript Latest Draft (ECMA-262)The definition of 'Property Accessors' in that specification. |
Draft |
|
ECMAScript 2015 (6th Edition, ECMA-262)The definition of 'Property Accessors' in that specification. |
Standard |
|
ECMAScript 5.1 (ECMA-262)The definition of 'Property Accessors' in that specification. |
Standard |
|
ECMAScript 1st Edition (ECMA-262)The definition of 'Property Accessors' in that specification. |
Standard |
Initial definition. Implemented in JavaScript 1.0. |
浏览器支持性
Feature |
Chrome |
Edge |
Firefox (Gecko) |
Internet Explorer |
Opera |
Safari |
---|---|---|---|---|---|---|
Basic support |
(Yes) |
(Yes) |
(Yes) |
(Yes) |
(Yes) |
(Yes) |
Feature |
Android |
Chrome for Android |
Edge |
Firefox Mobile (Gecko) |
IE Mobile |
Opera Mobile |
Safari Mobile |
---|---|---|---|---|---|---|---|
Basic support |
(Yes) |
(Yes) |
(Yes) |
(Yes) |
(Yes) |
(Yes) |
(Yes) |
Operators相关
JavaScript 是一种高级编程语言,通过解释执行,是一门动态类型,面向对象(基于原型)的解释型语言。它已经由ECMA(欧洲电脑制造商协会)通过 ECMAScript 实现语言的标准化。它被世界上的绝大多数网站所使用,也被世界主流浏览器( Chrome、IE、FireFox、Safari、Opera )支持。JavaScript 是一门基于原型、函数先行的语言,是一门多范式的语言,它支持面向对象编程,命令式编程,以及函数式编程。它提供语法来操控文本、数组、日期以及正则表达式等,不支持 I/O,比如网络