手動實現雙向綁定(簡略版)

使用defineproperty來定義setter、getter來進行攔截與更新Dom
Html:

<input id = 'input1' />
<input id = 'input2' />

JavaScrpt:

let model = { value: '' };
let vm = {};
Reflect.defineProperty(vm, 'value', {
  set(newValue) {
    Reflect.set(model, 'value', newValue);
    document.getElementById('input2').value = newValue;
    document.getElementById('input1').value = newValue;
  },
  get() {
    return Reflect.get(model, value);
  }
})
document.getElementById('input1').addEventListener('input', (e) => {
  vm.value = e.target.value;
})
document.getElementById('input2').addEventListener('input', (e) => {
  vm.value = e.target.value;
})
?著作權歸作者所有,轉載或內容合作請聯系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容