Расширить без переопределения

Я в некотором роде, чтобы сделать совместимость между XUI и Backbone, но я столкнулся с проблемой в моем дизайне. Похоже.

Вот оно Я хочу расширить XUI с помощью вызова метода attr который сможет справиться с хэшем attributes/values, jQuery делает, и Backbone использует его. Вот почему я хочу сделать это.

Повезло, там уже есть attr метод в XUI. Итак, когда я делаю:

xui.extend({
  attr:   function (attributes) {
    if (typeof attributes == "object") {
      for (var attr in attributes) {
        this.attr(attr, attributes[attr]);
      }
    };
  }
});

Конечно, у прото XUI есть только один метод attr. Мой. Как я могу иметь два?

Что-то делает следующее доступно:

xui(element).attr('attr', 'value');
xui(element).attr({'attr': 'value', 'foo': 'bar'});

Спасибо за чтение и помощь:)

1 ответ

Решение

Вам нужно сохранить ссылку на исходную функцию, а затем просмотреть аргументы, с которыми вызывается функция, чтобы определить, следует ли вам вызывать собственную версию или оригинал.

Примерно так (не проверенный код, поэтому используйте только для вдохновения):

var originalAttr = xui.attr;

xui.attr = function () {
  if(typeof arguments[0] === 'string') {
   originalAttr.apply(this, arguments);
  }
  else if(typeof arguments[0] === 'object') {
    for (var attr in attributes) {
      originalAttr.call(this, attr, attributes[attr]);
    }
  }
  else {
   /* unsupported arguments */
  }
};
Другие вопросы по тегам