日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Vue雙向綁定實現原理與方法詳解

瀏覽:124日期:2023-01-22 16:50:23

本文實例講述了Vue雙向綁定實現原理與方法。分享給大家供大家參考,具體如下:

昨天接到一個電話面試,上來第一個問題就是Vue雙向綁定的原理。當時我并不知道如何監聽數據層到視圖層的變化,于是沒答上來,掛電話后,我趕忙查了下資料,主要思路有如下三種。

1.發布者-訂閱者模式(backbone.js)

思路:使用自定義的data屬性在HTML代碼中指明綁定。所有綁定起來的JavaScript對象以及DOM元素都將“訂閱”一個發布者對象。任何時候如果JavaScript對象或者一個HTML輸入字段被偵測到發生了變化,我們將代理事件到發布者-訂閱者模式,這會反過來將變化廣播并傳播到所有綁定的對象和元素。

2.臟值檢查(angular.js)

思路:angular.js 是通過臟值檢測的方式比對數據是否有變更,來決定是否更新視圖,最簡單的方式就是通過 setInterval() 定時輪詢檢測數據變動,angular只有在指定的事件觸發時進入臟值檢測,大致如下:

DOM事件,譬如用戶輸入文本,點擊按鈕等。( ng-click ) XHR響應事件 ( $http ) 瀏覽器Location變更事件 ( $location ) Timer事件( $timeout , $interval ) 執行 $digest() 或 $apply()3.數據劫持(Vue.js)

思路: vue.js 則是采用數據劫持結合發布者-訂閱者模式的方式,通過Object.defineProperty()來劫持各個屬性的setter,getter,在數據變動時發布消息給訂閱者,觸發相應的監聽回調。

Vue雙向綁定實現原理與方法詳解

Object.defineProperty():方法會直接在一個對象上定義一個新屬性,或者修改一個對象的現有屬性, 并返回這個對象。

var obj = {}; Object.defineProperty(obj, ’hello’, { get: function() { console.log(’get val:’+ val); return val;   }, set: function(newVal) { val = newVal; console.log(’set val:’+ val); } });obj.hello=’111’;//控制臺打印set val:111obj.hello; //控制臺打印get val:111

當獲取hello屬性時,觸發get;設置hello值時,觸發set;這就是vue實現雙向綁定的核心

完整代碼如下

<!DOCTYPE html><html lang='en'><head><meta charset='UTF-8'><meta name='viewport' content='width=device-width, initial-scale=1.0'><meta http-equiv='X-UA-Compatible' content='ie=edge'><title>v-model</title></head><body><div id=’app’><h2>{{title}}</h2><input id=’i’ v-model=’text’ type='text'><h1>{{text}}</h1><button v-on:click=’clickMe’>click me</button></div><script>//Dom類 解析模板指令,將模板中的變量替換成數據,然后初始化渲染頁面視圖//并將每個指令對應的節點綁定更新函數,添加監聽數據的訂閱者,一旦數據有變動,收到通知,更新視圖class Doms {constructor(node, vm) {if (node) {this.$frag = this.nodeToFragment(node, vm)return this.$frag}}nodeToFragment(node, vm) {//將dom轉換成fragmentvar frag = document.createDocumentFragment()var child;while (child = node.firstChild) {this.compileElement(child, vm)frag.appendChild(child)}return frag}compileElement(node, vm) {//獲取v-model屬性,給dom賦值var reg = /{{(.*)}}/ //匹配雙括號里面的任何字符if (node.nodeType === 1) {//element元素var attr = node.attributes;for (var i = 0; i < attr.length; i++) {if (attr[i].nodeName == ’v-model’) {var name = attr[i].nodeValue//獲取綁定的keynode.addEventListener(’input’, function (e) {vm[name] = e.target.value//觸發set方法})new Watcher(vm, node, name, ’value’)} else if (attr[i].nodeName.includes(’:’)) {var eventType = attr[i].nodeName.split(’:’)[1]//事件名var cb = vm.methods && vm.methods[attr[i].nodeValue]if (eventType && cb) {node.addEventListener(eventType, cb.bind(vm), false)}}}if (node.childNodes && node.childNodes.length) {//如果還有子節點 遞歸[...node.childNodes].forEach(n => this.compileElement(n, vm))}}if (node.nodeType === 3) {//textif (reg.test(node.nodeValue)) {var name = RegExp.$1name = name.trim()new Watcher(vm, node, name, ’nodeValue’)}}}}class Vue {//Vue類constructor(params) {this.data = params.data //獲取屬性this.methods = params.methods //獲取方法this.observe(params.data, this)//監聽屬性var id = params.el;var dom = new Doms(document.getElementById(id), this)document.getElementById(id).appendChild(dom)params.mounted.call(this)}observe(obj, vm) {//讀取data內屬性,并監聽if (!obj || typeof obj !== ’object’) returnObject.keys(obj).forEach(key => this.defineReactive(vm, key, obj[key]))}defineReactive(obj, key, val) {//利用Object.defineProperty監聽屬性改變var dep = new Dep()Object.defineProperty(obj, key, {get: function () {if (Dep.target) {//添加訂閱者watcher到主題對象Depdep.addSub(Dep.target)}return val},set: function (newVal) {if (newVal === val) returnval = newValconsole.log(val)//作為發布者發布通知dep.notify()}})}}class Dep {//收集訂閱者的容器類constructor() {this.subs = []}addSub(sub) {this.subs.push(sub)}notify() {this.subs.forEach(sub => sub.update())}}class Watcher {constructor(vm, node, name, type) {Dep.target = thisthis.name = namethis.node = nodethis.vm = vmthis.type = typethis.update()Dep.target = null}update() {this.get()this.node[this.type] = this.value//訂閱者執行響應操作}get() {this.value = this.vm[this.name]//觸發響應屬性的get}}var vm = new Vue({el: ’app’,data: {text: ’lyl’,title: ’hello world’},methods: {clickMe() {this.title = ’hello world’}},mounted() {setTimeout(() => {this.title = ’你好’}, 1000);}})</script></body></html>

GitHub地址:https://github.com/ChrisLuckComes/Vue2WayBind

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼運行效果。

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《javascript面向對象入門教程》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》

希望本文所述對大家JavaScript程序設計有所幫助。

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日本免费久久| 中文字幕免费一区二区| 国产精品视区| 亚洲精品少妇| 99亚洲精品| 不卡福利视频| 国产v日韩v欧美v| 久久99久久人婷婷精品综合| 日韩av一区二| 亚洲丝袜美腿一区| 免费观看在线色综合| 一区二区三区网站| 日韩精品1区2区3区| 国产精品地址| av日韩中文| 91久久亚洲| 亚洲丝袜美腿一区| 婷婷亚洲五月| 欧美日本久久| 欧美aa在线观看| 日韩午夜视频在线| 久久久久中文| 久久精品99国产精品日本| 亚洲手机视频| 日韩av二区在线播放| 一区二区精品伦理...| 久久亚洲视频| 国产激情综合| 影音先锋国产精品| 奇米亚洲欧美| 中文字幕系列一区| 首页国产欧美日韩丝袜| 国产欧美欧美| 日韩成人综合| 亚洲va久久| 蜜臀av性久久久久蜜臀aⅴ流畅| 亚洲欧美网站在线观看| 蜜臀久久99精品久久久画质超高清 | 日韩激情视频网站| 你懂的网址国产 欧美| 久久精品影视| 欧美日韩黄网站| 韩国精品主播一区二区在线观看| 伊人成人在线视频| 久久97视频| 蜜桃免费网站一区二区三区| 国产欧美丝祙| 好看的av在线不卡观看| 美女国产精品久久久| 国产精品外国| 久久国内精品自在自线400部| 欧美日韩激情| 国产精品一区二区三区av麻 | 欧美一级精品| 欧美黄页在线免费观看| 亚洲欧美日韩专区| 亚洲先锋成人| 风间由美中文字幕在线看视频国产欧美| 久久亚洲二区| 国产午夜精品一区二区三区欧美 | 蜜臀91精品一区二区三区| 久久免费福利| 国产乱人伦精品一区| 一区二区高清| 亚洲综合丁香| 免费精品视频| 欧美一区二区三区高清视频| 欧美特黄一级大片| 色婷婷狠狠五月综合天色拍| 鲁大师精品99久久久| 免费在线观看精品| 亚洲综合电影一区二区三区| 亚洲国产一区二区三区在线播放 | 国产一区亚洲| 欧美片第1页| 久久精品国产亚洲夜色av网站| 国产精品一区二区av交换| 亚洲狼人精品一区二区三区| 喷白浆一区二区| 免费在线看一区| 国产精品v一区二区三区| 国产午夜一区| 国产网站在线| 一区视频在线| 国产日韩一区二区三区在线| 精品精品久久| 国产精品第一国产精品| 国产精品成久久久久| 日韩免费福利视频| 国产精品乱战久久久| 国产一区欧美| 精品日韩一区| 91精品日本| 日韩av字幕| 日韩av电影一区| 欧美在线黄色| 午夜亚洲福利| 免费在线观看一区| 精品三区视频| 精品视频高潮| 亚洲天堂久久| 日韩超碰人人爽人人做人人添| 国产精品天天看天天狠| 国产精品超碰| 美女网站一区| 日韩精品一页| 性欧美videohd高精| 老司机精品久久| 国产图片一区| 1024精品一区二区三区| 国产午夜一区| aa国产精品| 久久超级碰碰| 日韩一区欧美二区| 久久在线91| 日韩中文字幕1| 中文一区一区三区高中清不卡免费| 国产精品美女久久久浪潮软件| 美女久久一区| 亚洲天堂免费电影| 久久国内精品自在自线400部| 久久只有精品| 石原莉奈在线亚洲二区| 久久亚洲人体| 亚洲精品三级| 亚洲激情av| 夜鲁夜鲁夜鲁视频在线播放| 91精品美女| 日本视频中文字幕一区二区三区| 黄色亚洲精品| 久久精品不卡| 水蜜桃精品av一区二区| 国产精品大片免费观看| 午夜久久免费观看| 精品九九久久| 欧美国产极品| 国产精品美女午夜爽爽| 婷婷精品在线| 中文字幕一区二区三区在线视频| | 日韩av中文在线观看| 欧美日韩国产一区二区三区不卡| 国产成人在线中文字幕| 国产精品一区亚洲| 国产精品天堂蜜av在线播放| 欧美亚洲专区| 婷婷视频一区二区三区| 蜜臀久久久99精品久久久久久| 久久精品国产68国产精品亚洲| 日韩免费高清| 亚洲天堂一区二区| 久久精品免费一区二区三区| 欧美1区免费| 91九色精品国产一区二区| 久久国产影院| 国产一区清纯| 免费成人在线影院| 日本va欧美va精品发布| 国产精品传媒麻豆hd| 亚洲国产欧美日本视频| 国产suv精品一区| 国产一区二区三区不卡av| 精品视频在线你懂得| 亚洲深夜视频| 免费久久精品| 免费一级欧美在线观看视频 | 国产欧美欧美| 成人小电影网站| 亚洲欧美日韩高清在线| 亚洲一区成人| 免费一级欧美在线观看视频 | 91成人福利| 日韩精品看片| 亚洲伊人影院| 久久精品色播| 亚洲国产日韩欧美在线| 国产精品巨作av| 欧美在线观看视频一区| 日韩影片在线观看| 日韩国产激情| 青草国产精品| 蜜桃国内精品久久久久软件9| 日本va欧美va欧美va精品| 亚洲天堂成人| 免费在线亚洲欧美| 图片区亚洲欧美小说区| 国产午夜久久av| 日韩午夜黄色| 国产成年精品| 亚欧成人精品| 好看的亚洲午夜视频在线| 91亚洲国产| 国产精品乱战久久久| 亚洲一区av| 日韩精品dvd| 国产精品1luya在线播放| 亚洲精品亚洲人成在线观看| 国产99在线| av高清不卡| 福利在线一区|