javascript用defineProperty實現(xiàn)簡單的雙向綁定方法
defineProperty
Object提供的方法,用于給對象添加自定義屬性具體用法如下:
const obj = { _value: 1 };Object.defineProperty(obj, ’value’, { get: function() { console.log(’get方法執(zhí)行’); return this._value; }, set: function(a) { console.log(’set方法執(zhí)行’); this._value = a; }})obj.value = 3;console.log(obj.value);console.log(obj._value);
在node中執(zhí)行結(jié)果如下:
下面來分析一下代碼首先定一個對象,并對對象添加一個自定義屬性value,同時添加了getter,setter兩個函數(shù)用來分別控制value屬性的修改和獲取,當(dāng)執(zhí)行obj.value = 3;時,會自動調(diào)屬性的setter方法,將value的修改同步到_value屬性上,當(dāng)執(zhí)行obj.value語句獲取屬性值時,會自動調(diào)用getter方法獲取方法的返回值;
總結(jié) (參考MDN)該方法接收三個參數(shù)obj:要添加屬性的對象prop: 要定義的屬性descriptor:要定義或者修改的屬性描述符其中描述符包含以下幾種
1.configurable:布爾值,控制屬性是否能改變(除了value,writable)及刪除2.enumerable: 布爾值,控制屬性是否可枚舉,即通過for in循環(huán)或者Object.keys訪問3.value:屬性值,可以時任何有效JavaScript值4.writable 布爾值,屬性可否通過賦值修改5.get:屬性getter函數(shù),執(zhí)行時傳入this,this值取決于調(diào)用者6.set:屬性setter函數(shù),賦值時執(zhí)行,并傳入this
雙向綁定
由此可以設(shè)計一下數(shù)據(jù)雙向綁定的簡單實現(xiàn):在數(shù)據(jù)對象內(nèi)定義屬性,通過對dom綁定事件監(jiān)聽dom內(nèi)值的變化,并賦值給數(shù)據(jù)對象,數(shù)據(jù)對象的改動會調(diào)用自身的setter方法,在方法內(nèi)在動態(tài)修改dom內(nèi)容。
代碼如下:
<!-- 簡單數(shù)據(jù)雙向綁定實現(xiàn) --><!DOCTYPE html><html> <head> <meta charset='utf-8'> </head> <body> <div id='root'> <button id=’btn’>請求數(shù)據(jù)</button> </div> </body> <script> const root = document.getElementById(’root’); const btn = document.getElementById(’btn’); const input = document.createElement(’input’); const model = document.createElement(’p’); const dataModel = { _value:0, } Object.defineProperty(dataModel, ’value’, { configurable: true, set:function(value){this._value = value;input.value = value;model.innerHTML = `<span>數(shù)據(jù)模型:</sapn> ${value}`; }, get:function(){return this._value; } }) btn.addEventListener(’click’, () => { const range = Math.floor(Math.random(0, 1) * 100); dataModel.value = range; }) input.addEventListener(’input’,(ev) => { dataModel.value = ev.target.value; }) const initPage = () => { dataModel.value = 100; } initPage(); root.append(input); root.append(model); </script></html>
描述有點亂,看實現(xiàn)代碼更清晰一點,有問題歡迎指正
到此這篇關(guān)于javascript用defineProperty實現(xiàn)簡單的雙向綁定方法的文章就介紹到這了,更多相關(guān)javascript defineProperty雙向綁定內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 使用 kind 和 Docker 啟動本地的 Kubernetes環(huán)境2. idea設(shè)置自動導(dǎo)入依賴的方法步驟3. 解決python中import文件夾下面py文件報錯問題4. XML入門精解之結(jié)構(gòu)與語法5. ASP基礎(chǔ)入門第八篇(ASP內(nèi)建對象Application和Session)6. IntelliJ IDEA設(shè)置編碼格式的方法7. IntelliJ IDEA設(shè)置默認(rèn)瀏覽器的方法8. idea自定義快捷鍵的方法步驟9. IntelliJ IDEA設(shè)置條件斷點的方法步驟10. Idea如何去除Mapper警告方法解析
