本文小編為大家詳細介紹“vue如何實現響應式與雙向數據”,內容詳細,步驟清晰,細節(jié)處理妥當,希望這篇“vue如何實現響應式與雙向數據”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
公司主營業(yè)務:做網站、成都做網站、移動網站開發(fā)等業(yè)務。幫助企業(yè)客戶真正實現互聯網宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯公司是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯公司推出建陽免費做網站回饋大家。
Vue 最獨特的特性之一,是其非侵入性的響應式系統。數據模型僅僅是普通的 JavaScript對象。而當你修改它們時,視圖會進行更新。這使得狀態(tài)管理非常簡單直接,不過理解其工作原理同樣重要,這樣你可以避開一些常見的問題。在這個章節(jié),我們將研究一下
Vue 響應式系統的底層的細節(jié)。
數據響應式:數據模型僅僅是普通的JavaScript對象,而當我們修改數據時,視圖會進行更新,避免了頻繁的DOM操作,提高開發(fā)效率,這與Jquery不一樣,Jquery是頻繁的操作Dom
數據改變,視圖改變,視圖改變,數據也隨之改變( 通過這句話,我們可以看到在雙向綁定中是包含了數據響應式的內容)
我們可以使用v-model 在表單元素上創(chuàng)建雙向數據綁定
數據驅動是Vue最獨特的特性之一
開發(fā)過程中僅僅需要關注數據本身,不需要關心數據是如何渲染到視圖中的。主流的MVVM框架都已經實現了數據響應式與雙向綁定,所以可以將數據綁定到DOM上。
在vue.js中,所謂的數據驅動就是當數據發(fā)生變化的時候,用戶界面發(fā)生相應的變化,開發(fā)者不需要手動的去修改dom。
那么vuejs是如何實現這種數據驅動的呢?
vue實現數據雙向綁定主要是:采用數據劫持結合發(fā)布者-訂閱者模式的方式,通過Object.defineProperty()來劫持各個屬性的setter,getter,在數據變動時發(fā)布消息給訂閱者,觸發(fā)相應監(jiān)聽回調。當把一個普通Javascript 對象傳給 Vue 實例來作為它的 data 選項時,Vue 將遍歷它的屬性,用Object.defineProperty 將它們轉為 getter/setter。用戶看不到 getter/setter,但是在內部它們讓Vue 追蹤依賴,在屬性被訪問和修改時通知變化。
vue的數據雙向綁定
將MVVM作為數據綁定的入口,整合Observer,Compile和Watcher三者,通過Observer來監(jiān)聽自己的model的數據變化,通過Compile來解析編譯模板指令(vue中是用來解析{{}}),最終利用watcher搭起observer和Compile之間的通信橋梁,達到數據變化—>視圖更新;視圖交互變化(input)—>數據model變更雙向綁定效果。
代碼如下(示例):