02.12.2013, 02:34
|
Аспирант
|
|
Регистрация: 30.11.2013
Сообщений: 42
|
|
|
|
02.12.2013, 02:35
|
|
junior
|
|
Регистрация: 29.11.2011
Сообщений: 3,924
|
|
Сообщение от Antonius
|
во-первых это лишний элемент в пространстве имен, помимо самого конструктора, а во-вторых (и это главное) не могу придумать имя, которое бы было коротким, понятным, и при этом не было похоже на типичное имя переменной
|
var obj = Constructor.create(params);
Constructor.create = function(params) {
return new Constructor(params);
};
__________________
Чебурашка стал символом олимпийских игр. А чего достиг ты?
Тишина - самый громкий звук
Последний раз редактировалось nerv_, 02.12.2013 в 02:39.
|
|
02.12.2013, 02:36
|
|
Быдлокодер;)
|
|
Регистрация: 19.11.2010
Сообщений: 4,338
|
|
Сообщение от nerv_
|
Тот, кто используют приватные методы извне - сам дурак
|
золотые слова
К слову, если очень нужно запретить изменение метода, то можно использовать "заморозку" (seal, freeze, preventExtensions), но не понимаю зачем, ибо если челочек осмысленно юзает приватные методы извне, то он априори не прав.
|
|
02.12.2013, 02:50
|
Аспирант
|
|
Регистрация: 30.11.2013
Сообщений: 42
|
|
Насчет того, как принято в JS, кажется начинаю понимать
В принципе некоторый опыт с другими языками (в том числе ООП) был, но давно. И по сравнению с ними в JS все как-то непривычно, кажется, надо просто понять, что «тут это нормально».
Кстати, где можно почитать насчет seal, freeze, preventExtensions и т. д. Использовать здесь точно не буду, просто чтобы быть в курсе...
nerv_, это понятно, сам о таком думал, но особенности задачи таковы, что такая запись будет слишком громоздкой, предполагаю, что в коде чаще будет много коротких цепочек вызовов, и там такая длинная инициализация будет перегружать исходник и ухудшать читаемость.
Если бы объекты создавались редко, а затем интенсивно модифицировались — можно было бы и так, но пока мне кажется, что именно для этой задачи — не очень красивый вариант.
Последний раз редактировалось Antonius, 02.12.2013 в 02:57.
|
|
02.12.2013, 11:56
|
|
junior
|
|
Регистрация: 29.11.2011
Сообщений: 3,924
|
|
Сообщение от Antonius
|
Кстати, где можно почитать насчет seal, freeze, preventExtensions и т. д. Использовать здесь точно не буду, просто чтобы быть в курсе...
|
http://learn.javascript.ru/descriptors-getters-setters
Сообщение от Antonius
|
Если бы объекты создавались редко, а затем интенсивно модифицировались — можно было бы и так, но пока мне кажется, что именно для этой задачи — не очень красивый вариант.
|
можешь использовать "Шаблоны принудительного использования new":
1.
'use strict';
function Waffle() {
alert(this === undefined);
this.tastes = 'yummy';
}
new Waffle();
Waffle();
В строгом режиме ES5 ссылка this больше не указывает на глобальный объ-
ект.
2.Возвращать из конструктора "другой" объект:
function Waffle() {
var obj = Object.create(Waffle.prototype);
obj.tastes = 'yummy';
alert(obj instanceof Waffle);
return obj;
}
new Waffle();
Waffle();
3.Использовать конструктор вызывающий сам себя:
function Waffle() {
if (!(this instanceof Waffle)) {
return new Waffle();
}
this.tastes = 'yummy';
alert(this instanceof Waffle);
}
new Waffle();
Waffle();
*писал на скорую руку, мог ошибиться...
__________________
Чебурашка стал символом олимпийских игр. А чего достиг ты?
Тишина - самый громкий звук
Последний раз редактировалось nerv_, 02.12.2013 в 15:41.
|
|
02.12.2013, 13:22
|
Профессор
|
|
Регистрация: 18.11.2013
Сообщений: 275
|
|
Сообщение от nerv_
|
В строгом режиме ES5 ссылка this больше не указывает на глобальный объ-
ект.
|
в смысле при вызове любой функции всегда создается Object.create(func.prototype) ????
|
|
02.12.2013, 14:49
|
|
Быдлокодер;)
|
|
Регистрация: 19.11.2010
Сообщений: 4,338
|
|
Сообщение от Maxmaxmaximus3
|
в смысле при вызове любой функции всегда создается Object.create(func.prototype) ????
|
Если у функции не указан объект вызова, то он равен undefined (вместо window как раньше было)
|
|
02.12.2013, 17:08
|
Аспирант
|
|
Регистрация: 30.11.2013
Сообщений: 42
|
|
nerv_, спасибо Первый способ не подходит, поскольку требует обязательного использования "use strict", но на будущее буду иметь в виду. Остальные — интересно.
Все-таки учиться только самостоятельно по источникам в учебниках, литературе не так эффективно, вот даже по простым вопросам общение с более опытными разработчиками сразу приносит ощутимую пользу.
|
|
09.12.2013, 06:53
|
Аспирант
|
|
Регистрация: 30.11.2013
Сообщений: 42
|
|
Пожалуй, придется поднять тему снова
Возник такой вопрос (опять же из разряда «как принято поступать в таких случаях»). Опять же не знаю, пригодится оно мне в итоге или нет, но разобраться в любом случае хочется.
В корневом объекте, который объявлен в скрипте, есть поля, в свою очередь хранящие структурированную информацию. Например, координаты
{ x: 1, y: 2}
. Сейчас, чтобы проверить, что там действительно находятся координаты, иногда приходится использовать проверки типа
if (this.coord && typeof this.coord.x == 'number' && typeof this.coord.y == 'number') {…}
Например, если данные получены извне и еще не провалидированы.
Есть мысль объявить для таких объектов конструкторы и проверять
if (this.coord instanceof Coord) {…}
Валидировать можно при инициализации объекта, например.
Опять возникает проблема засорения пространства имен. Библиотека уже объявляет корневой объект (например, LibraryRoot, сам является конструктором), и не хочется помимо него вводить отдельные конструкторы.
Пока приходит в голову только объявлять конструкторы как LibraryRoot.Coord, но что-то меня смущает в этом варианте. Собственно, вопрос, нормально ли это или есть способы получше?
|
|
09.12.2013, 08:16
|
|
Быдлокодер;)
|
|
Регистрация: 19.11.2010
Сообщений: 4,338
|
|
LibraryRoot.Coord. Нормально, много так где сделано.
|
|
|
|