Esta tradução está incompleta. Ajude atraduzir este artigo.
Os assessores de propriedade fornecem acesso as propriedades de um objeto usando a notação de ponto ou a notação de colchetes.
Sintaxe
object.property object["property"]
Descrição
Pode-se pensar em um objeto como uma matriz associativa (a.k.a. map, dictionary, hash, lookup table). As chaves nesta matriz são os nomes das propriedades dos objetos. É típico quando se fala de propriedades de um objeto para fazer uma distinção entre propriedades e métodos. No entanto, a distinção entre propriedade/método é um pouco mais do que convenção. Um método é simplesmente uma propriedade que pode ser chamada, por exemplo, se tiver uma referência a uma instância de Function como seu valor.
Há duas maneira de acessar propriedades: notação de ponto ou a notação de colchetes.
Notação de ponto
get = object.property; object.property = set;
Neste código, a propriedade deve ser um identificador válido, i.e. uma sequência de carácteres alfanuméricos, incluíndo também o underline ("_
") e o cifrão ("$
"), não pode começar com um número. Por exemplo, object.$1
é valido, enquanto object.1
não é.
document.createElement('pre');
Aqui, o método chamado "createElement" é recuperado do documento e é chamado.
Se você usar um método para um literal numérico e o literal numérico não tem expoente e nenhum ponto decimal, deixar de espaço em branco antes do ponto que precede a chamada de método para evitar que o ponto seja interpretado como um ponto decimal.
77 .toExponential(); // ou 77 .toExponential(); // ou (77).toExponential(); // ou 77..toExponential(); // ou 77.0.toExponential(); // porque 77. === 77.0, sem ambiguidade :p
Notação de colchete
get = object[property_name]; object[property_name] = set;
property_name
é uma string. A string não precisa ser um identificador válido; pode ser qualquer valor, e.g. "1foo", "!bar!", ou até " " (um espaço).
document['createElement']('pre');
Isto faz exatamente a mesma coisa que o exemplo anterior.
Um espaço antes da notação de colchete é permitido.
document ['createElement']('pre');
Nomes de propriedades
Nomes de propriedades devem ser strings. Isto significa que objetos não-string não podem ser usados como chave em um objeto. Qualquer objeto não-string, incluindo um número, é estereotipado como uma string pelo método toString.
var object = {}; object['1'] = 'value'; console.log(object[1]);
A saída é "value", desde 1 é estereotipado como '1'.
var foo = {unique_prop: 1}, bar = {unique_prop: 2}, object = {}; object[foo] = 'value'; console.log(object[bar]);
A saída também é "value", já que ambos foo e bar são convertidos para a mesma string. No motor de Javascript SpiderMonkey, esta string poderia ser "['object Object']".
Ligação de método
Um método não é limitado ao objeto de quem é metodo. Especificamente, this
não é fixo em um método, i.e., this
não se referece necessariamente ao objeto contendo o método. Ao invés disso, this
é "passado" pela função call. Veja method binding.
Nota sobre eval
Novatos em JavaScript comentem muitas vezes o erro de usar eval onde a notação de colchete pode ser usada no lugar. Por exemplo, a sintaxe a seguir é muitas vezes vista em muitos scripts.
x = eval('document.forms.form_name.elements.' + strFormControl + '.value');
eval
é lento e deve ser evitado sempre que possível. Também, strFormControl
would have to hold an identifier, which is not required for names and IDs of form controls. It is better to use bracket notation instead:
x = document.forms["form_name"].elements[strFormControl].value;
Especificações
Specification | Status | Comment |
---|---|---|
ECMAScript 2017 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. |
Compatibilidade entre navegadores
Feature | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|---|
Basic support | (Yes) | (Yes) | (Yes) | (Yes) | (Yes) |
Feature | Android | Chrome for Android | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|---|
Basic support | (Yes) | (Yes) | (Yes) | (Yes) | (Yes) | (Yes) |