国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

淺談vue實現雙向事件綁定v-model的原理

瀏覽:106日期:2023-02-11 08:16:10
目錄解釋:總結補充

與js或者jquery直接改變操作dom不同,vue使用v-model實現數據的雙向綁定,它會根據控件類型自動選取正確的方法來更新元素。

v-model就是vue的雙向綁定的指令,能將頁面上控件輸入的值同步更新到相關綁定的data屬性,也會在更新data綁定屬性時候,更新頁面上輸入控件的值

官方文檔這么解釋:

v-model只不過是一個語法糖而已,真正的實現靠的還是

v-bind:綁定響應式數據 觸發 input 事件 并傳遞數據 (核心和重點)

如下代碼

<input v-model='txt'>

本質上是

<input :value='txt' @input='txt = $event.target.value'>解釋:

初始化vue實例時候,會遞歸遍歷data的每一個屬性,并且通過defineProperty來監聽每一個屬性的get,set方法,從而一旦某個屬性重新賦值,則能監聽到變化來操作相應的頁面控制

看下方代碼:

Object.defineProperty(data,'name',{get(){ return data['name'];},set(newVal){ let val=data['name']; if (val===newVal){return; } data['name']=newVal; // 監聽到了屬性值的變化,假如node是其對應的input節點 node.value=newVal;}})總結

一方面modal層通過Object.defineProperty來劫持每個屬性,一旦監聽到變化通過相關的頁面元素更新。另一方面通過編譯模板文件,為控件的v-model綁定input事件,從而頁面輸入能實時更新相關data屬性值

那么Object.defineProperty是用來控制一個對象屬性的一些特有操作,比如讀寫權、是否可以枚舉,這里我們主要先來研究下它對應的兩個描述屬性get和set,v-model其實是對其get和set進行重寫操作,get就是在讀取name屬性這個值觸發的函數,set就是在設置name屬性這個值觸發的函數

補充

v-model修飾符:.lazy、.trim和.number

lazy :在每次 input 事件觸發后將輸入框的值與數據進行同步,添加 lazy 修飾符,從而轉變為使用 change 事件進行同步

<input v-model.lazy='msg'>

trim :去除字符串首尾的空格

<input v-model.trim='msg'>

number :將數據轉化為值類型

<input v-model.number='msg'>

到此這篇關于淺談vue實現雙向事件綁定v-model的原理的文章就介紹到這了,更多相關vue 雙向事件綁定v-model內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Vue
相關文章:
主站蜘蛛池模板: 一级做a爰片久久毛片人呢 一级做a爰片久久毛片唾 | 亚洲综合国产一区在线 | 久久精品成人免费网站 | 国产精品成人一区二区三区 | 欧美手机在线视频 | 91原创视频在线观看 | 亚洲专区一 | 国产成人久久精品一区二区三区 | 国产精品成人久久久久久久 | 亚洲三级视频在线观看 | 亚洲精品视频免费看 | 国产老鸭窝毛片一区二区 | 日本高清精品 | 兔费看全黄三级 | www.乱 | 欧美日韩视频在线第一区二区三区 | 在线视频日本 | av人摸人人人澡人人超碰 | 国产免费午夜a无码v视频 | 久久精品高清 | 免费在线一区二区三区 | 午夜精品尤物福利视频在线 | 在线亚洲精品国产波多野结衣 | 99久久免费中文字幕精品 | 国产理论最新国产精品视频 | 亚洲国产一区二区三区四区 | 99久久99久久精品免费看子 | 九色91 | 新婚第一次一级毛片 | 国产日韩精品一区在线观看播放 | 91久久国产综合精品女同国语 | 三级网站在线免费观看 | 成人国产在线不卡视频 | 一区二区三区网站在线免费线观看 | 亚洲精品一区 | 国产不卡精品一区二区三区 | 国产亚洲欧美日韩在线观看一区二区 | 五月色婷婷综合开心网亚 | 亚洲精品视频网 | 亚洲毛片在线看 | aaa成人永久在线观看视频 |