#javascript
Вот у меня есть код:
class BaseInput{
constructor(value){
this.makeButtonVisible = null;
this.makeButtonVisible = function(){
alert(1234);
};
this.makeButtonInvisible = null;
this._input = document.createElement('input');
this._input.type = 'text';
this._input.value = value;
this._input.dataset.value = value;
this._input.oninput = function(){
if (this.value != this.dataset.value)
BaseInput.makeButtonVisible();
else
alert(321);
}
document.querySelector('.container').appendChild(this._input);
}
}
в this._input.oninput я добавляю функцию, которая должна обратиться к методам makeButtonVisible
или makeButtonInvisible этого объекта
Ответы
Ответ 1
this._input.dataset.value = value; this._input.logic = this; this._input.oninput = function(e) { if (this.value != this.dataset.value) this.logic.makeButtonVisible(); else alert(321); }; или this._input.dataset.value = value; this._input.oninput = (e) => { if (this._input.value != this._input.dataset.value) this.makeButtonVisible(); else alert(321); }; или this._input.dataset.value = value; this._input.oninput = (function(e) { if (this._input.value != this._input.dataset.value) this.makeButtonVisible(); else alert(321); }).bind(this);
Комментариев нет:
Отправить комментарий