Javascript-форум (https://javascript.ru/forum/)
-   Общие вопросы Javascript (https://javascript.ru/forum/misc/)
-   -   Добавление объекта с методами к конструктору (https://javascript.ru/forum/misc/74990-dobavlenie-obekta-s-metodami-k-konstruktoru.html)

SuperZen 24.08.2018 13:25

var CreateTest = function CreateTest(name) {
  this.name = name
  this.roll = () => ['simple', 'hard'][Math.round(Math.random())]
}

CreateTest.prototype.renameObj = function () {
  return {
    rename: () => {
      return this.name = `${this.roll()} ${this.name}`
    }
  }
}

var test = new CreateTest('js test')
console.log(test.renameObj().rename())


мои 5 копеек %)

Alexandroppolus 24.08.2018 13:33

Цитата:

Сообщение от R2R (Сообщение 493304)
Т.е. пользователь может написать простую функцию, меняющую координаты элемента по некой формуле, поместив ее со своими параметрами в объект, затем вызвать ее через функцию обертку с промисом и raf. При этом он абстрагируется от асинхронной логики и думает только над уравнением перемещения. Чтобы это осуществить, как раз и требуется добавить объект в конструктор (тоже через обертку, чтобы это мог делать пользователь-новичок, не знакомый с ООП в js).

надо передавать в параметры некоторую пользовательскую функцию, которую твой класс будет сам вызывать?

примерно так
function CreateTest(params) {
  this.name = params.name;
  this._calcFunc = params.calcFunc;
}

CreateTest.prototype = {
  constructor: CreateTest,

  move: function() {
    var calcResult = this._calcFunc();
    // ...
  }
};


var test = new CreateTest({
  name: '...',
  calcFunc: function() { return 2 + 2; }
});

test.move();

R2R 24.08.2018 19:52

SuperZen, все бы хорошо, только надо передавать объект, а не функцию)

Alexandroppolus, надо передавать в функцию объект, чтобы он записывался в конструктор.

Aetae, Ваша реализация очень хороша, я немного подкорректировал ее:
function CreateTest(name) {
    this.name = name;
    this.roll = () => ["simple", "hard"][Math.round(Math.random())];
}

function bindedAppend(parent, name, child) {
    Object.defineProperty(parent.prototype, name, {
        configurable: true,
        enumerable: true,
        get: function() {
            return this[name] = new Proxy(this, {
                get: (p, key) => key in child ? child[key] : this[key],
                set: (p, key, val) => this[key] = val
            })
        }
    });                  
};

bindedAppend(CreateTest, 'renameObj', {
    value : 7,
    rename: function() {
        return this.name = `${this.roll()} ${this.name}`;
    }
});

let test3 = new CreateTest("js test");

test3.renameObj.rename();

console.log(test3.name, test3.renameObj.value);

Придумаю потом, как объявить bindedAppend в конструкторе, будет совсем конфетка)


Часовой пояс GMT +3, время: 21:21.