Javascript.RU

Аксессоры

Описание, примеры

Операторы-аксессоры предоставляют доступ к свойствам объекта.

Объект представляет собой обычный ассоциативный массив (словарь, хэш). Ключами этого массива являются имена свойств и методов (свойств, являющихся ссылкой на функцию).

Есть два способа доступа к свойствам: запись с точкой или с квадратными скобками.

Запись с точкой

Пример: запись с точкой
get = object.property // получить свойство property
object.property = set  // записать свойство property

Для записи с точкой название свойства должно быть правильным javascript-идентификатором, то есть последовательностью английских букв и цифр, включая подчеркивание "_" и знак доллара "$", которая не начинается с числа.
Например, object.$1 - корректный идентификатор, а object.1 - нет.

document.createElement('pre')

В этом примере из объекта document получено свойство createElement, которое является ссылкой на функцию. Эта функция вызвана с аргументом 'pre' в контексте объекта document.

Запись с квадратными скобками

Пример: квадратные скобки
get = object[property_name] // получить
object[property_name] = set  // записать

Здесь property_name - строка. Она не обязательна является правильным идентификатором. Может быть любое значение, включая цифры и даже " " (пробел).

document['createElement']('pre')

Этот пример делает в точности то же самое, что и аналогичный предыдущий.

Использование eval

В старых javascript-скриптах иногда используется доступ к свойствам объекта через eval, в то время как гораздо быстрее и правильнее использовать запись с квадратными скобками.

Например, часто попадается такая запись:

Пример: устаревшая запись
x = eval('document.form_name.' + strFormControl + '.value')

Следует максимально избегать вызова eval. Лучше использовать скобочную запись:

Пример: скобочная запись
x = document.form_name[strFormControl].value

См. также


Автор: jetli13, дата: 8 июля, 2010 - 09:45
#permalink

По поводу eval.
Можно ли обойтись без него в такой ситуации:

function Obj()
{
  this.firstFucn = function()
  {
    return 'yo';
  }

  this.secondFunc = function()
  {
    return 'yo2';
  }
}

var obj = new Obj();
var functions = ['first', 'second'];

eval('obj.' + functions[0] + 'Func()');
eval('obj.' + functions[1] + 'Func()');

Автор: Sweet, дата: 17 августа, 2010 - 23:59
#permalink

Конечно, можно:

var obj = {
  firstFunc: function(){
    return 'yo'
  },
  secondFunc: function(){
    return 'yo2'
  }
}, functions = ['first', 'second']
obj[functions[0]+'Func']()
obj[functions[1]+'Func']()

Автор: Дзен-трансгуманист, дата: 15 июля, 2012 - 15:06
#permalink

Хороший перевод, спасибо. Кому интересно - оригинал статьи здесь.


 
Поиск по сайту
Содержание

Учебник javascript

Основные элементы языка

Сундучок с инструментами

Интерфейсы

Все об AJAX

Оптимизация

Разное

Дерево всех статей

Последние темы на форуме
Forum