您好,登錄后才能下訂單哦!
今天小編給大家分享一下Vue實現MVVM的方法是什么的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
1. Object.defineProperty() 定義屬性
用意:給一個對象定義屬性,那個屬性原來是不存在的。這是一個初衷,屬性是不存在的,需要額外添加。
①、使用說明
Object.defineProperty(obj,props)
第一個參數是將被添加或者修改的屬性的對象
第二個參數是一個對象,表示將要添加的一個或多個鍵值對一直要添加屬性的具體配置
{
'屬性名':{value:'...',writable:true},
'屬性名':{value:'...',writable:true}
}
②、屬性的getter和setter
一般用于局部變量
給構造函數添加屬性
// get和set的方法不能和value以及writable一起使用 var o ={}, Object.defineProperty(o,'p',{ get(){ console.log('調用屬性后輸出') }, set(val){ console.log(val+'賦值屬性的時候調用') } }) o.p // '調用屬性后輸出' o.p = 'hcc' //hcc賦值屬性的時候調用 // 可以根據Object.getOwnPropertyDescriptor(對象, '屬性名')得到相應的屬性配置 // 需求 //給一個對象的屬性值不能超過30,超過30的按照30來算 var hcc = {} //全局對象 { var age = null //局部變量 Object.defineProperty(hcc,'age',{ get(){ return age //設置hcc.age的值 }, set(val){ age= val> 30?30:val //當賦值給hcc.age的值進行判定從而改變局部變量age的值 } }) }
③、使用場景
// 簡單的給元素添加屬性 var obj = {name:'hcc'} Object.defineProperties(obj,{ 'name':{value:'haaaaa',writable:true}, 'age':{value:24,writable:false} })
細節
今天樓主上午在思考,一般使用Object.defineProperty()為什么需要使用局部變量呢?
所有樓主就下了下面的代碼
var obj = {} Object.defineProperty(obj,'a',{ get() { return 'gg'; }, set(value) { obj.a = value; } })
解析: 為什么會出現堆溢棧呢 ? 我們在調用 obj.a = 'ff' 的時候,觸發了set()方法,從而執行了obj.a = value,又給obj.a進行了賦值,調用set()方法,進入了死循環。
總結: 所以我們在使用Object.defineProperty()的時候,都是通過一個私有變量或者一個局部變量來實現對象的屬性的賦值和設置。
// 局部變量,以一個變量為軀殼,設置返回值。 const obj = {} { let bValue; Object.defineProperty(obj,'a',{ get(){ return bValue }, set(value) { bValue = value; } }) } // 私有變量 const obj = { _data: { a: null } } Object.defineProperty(obj,'a', { get() { return obj._data.a }, set(value) { obj._data.a = value } })
總結: Vue中進行雙向綁定就是通過私有變量data實現的。是不是和Vue的結構很相似。
實現Vue的雙向綁定
實現改變元素的值的時候,dom進行相應的更新數據。
dom的值進行更新的時候,元素的值同時也改變。
html部分
<div class="forms"> <span>姓名</span> <input type='text' name="name"> <span>年齡</span> <input type='text' name="age"> </div>
js部分
// 改變input的值得同時obj的值改變 const obj = { _data: { name: null, age: null } } const nameInput = document.querySelector('input[name]') nameInput.addEventListener('input', (e) => { obj._data.name = e.target.value; }) Object.definePeoperty(obj,'a',{ get() { return obj._data.name }, set(value) { nameInput.value = value; obj._data.name = value; } }) // 簡化 function bind(obj,dom) { let name = dom.getAttribute('name'); Object.defineProperty(obj,name,{ get() { return obj._data[name] }, set(value) { dom.value = value; obj._data[name] = value; } }) dom.addEventListener('input', (e) => { obj._data[name] = e.target.value; }) } bind(obj,document.querySelector('input[name=name]')) bind(obj,document.querySelector('input[name=age]'))
缺點: 必須要事先的綁定dom。是不是和Vue里面的很想,必須事先申明data中的數據,如果需要額外的添加數據的時候,必須通過Vue.set()來申明。
Vue是一款友好的、多用途且高性能的JavaScript框架,使用vue可以創建可維護性和可測試性更強的代碼庫,Vue允許可以將一個網頁分割成可復用的組件,每個組件都包含屬于自己的HTML、CSS、JavaScript,以用來渲染網頁中相應的地方,所以越來越多的前端開發者使用vue。
以上就是“Vue實現MVVM的方法是什么”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。