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

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

Vue 數(shù)據(jù)響應式相關總結

瀏覽:33日期:2022-10-08 11:25:59

在說數(shù)據(jù)響應式之前,我們要解決一個很重要的問題,那就是Vue到底對data做了什么?先從getter和setter說起,我們用那個他們來對虛擬的屬性進行讀寫。

getter和setter

有如下代碼

let obj0 = { 姓: '高', 名: '圓圓', age: 18};// 需求一,得到姓名let obj1 = { 姓: '高', 名: '圓圓', 姓名() { return this.姓 + this.名; }, age: 18};console.log('需求一:' + obj1.姓名());//高圓圓

此時我們log出來的結果是高圓圓,這個大家都能看懂,但是姓名后面的括號能刪掉嗎?不能,因為它是函數(shù),那么我們怎么去掉括號呢?下面就有我們的需求二

// 需求二,姓名不要括號也能得出值let obj2 = { 姓: '高', 名: '圓圓', get 姓名() { return this.姓 + this.名; }, age: 18};console.log('需求二:' + obj2.姓名);//高圓圓

此時我們使用getter ,不加括號也能得出值。那么我們要怎么改變這個名字呢?

// 需求三:姓名可以被寫let obj3 = { 姓: '高', 名: '圓圓', get 姓名() { return this.姓 + this.名; }, set 姓名(xxx){ this.姓 = xxx[0] this.名 = xxx.slice(1) }, age: 18};obj3.姓名 = ’高媛媛’console.log(`需求三:姓 ${obj3.姓},名 ${obj3.名}`)//高媛媛

有get就有set,setter就是這樣用的。我們用 屬性值 = xxx 觸發(fā) set 函數(shù),姓名就可以被寫啦。但是我們在需求三中打出 console.log(obj3) 會得到如下圖所示:

Vue 數(shù)據(jù)響應式相關總結

如圖為什么會顯示 姓名:(...) 呢? 這其實是一個get set,瀏覽器在顯示這個姓名的時候就打印出 姓名:(...) ,這說明我們可以在需求三中對姓名進行讀和寫,但是并不存在一個叫做姓名的屬性,而是有get和set來模擬對姓名進行的操作。

Object.defineProperty

在如上例子中,我們在定義對象的時候就直接使用get和set,但是如果對象已經被聲明完了,那我們怎么繼續(xù)加上get呢?我們就要用到Object.defineProperty,還是需求三,我們加入如下代碼就可以在定義完之后再加get和set了:

var _xxx = 0Object.defineProperty(obj3,’xxx’,{ get(){ return _xxx }, set(value){ _xxx= value }})

接下來我們就可以解決一開始的問題了:Vue到底對data做了什么?我們舉幾個例子看看:

let data0 = { n: 0}

先聲明一個data0,需求一:用 Object.defineProperty 定義 n:

let data1 = {}Object.defineProperty(data1, ’n’, { value: 0})console.log(`需求一:${data1.n}`)//需求一:0

需求二:n 不能小于 0:

let data2 = {}data2._n = 0 // _n 用來偷偷存儲 n 的值,默認為0Object.defineProperty(data2, ’n’, { get(){ return this._n }, set(value){ if(value < 0) return this._n = value }})console.log(`需求二:${data2.n}`)//0data2.n = -1console.log(`需求二:${data2.n} 設置為 -1 失敗`)//0設置為 -1 失敗data2.n = 1console.log(`需求二:${data2.n} 設置為 1 成功`)//0設置為 1 成功

可是如果對方直接使用data2._n呢?我們能不能做到不在對象上暴露任何能夠被訪問的東西呢?這時候我們就要使用代理:

let data3 = proxy({ data:{n:0} }) // 括號里是匿名對象,無法訪問function proxy({data}){ const obj = {} // 這里的 ’n’ 寫死了,理論上應該遍歷 data 的所有 key,這里做了簡化 // 因為我怕你們看不懂 Object.defineProperty(obj, ’n’, { get(){ return data.n }, set(value){ if(value<0)return data.n = value } }) return obj // obj 就是代理}// data3 就是 objconsole.log(`需求三:${data3.n}`)data3.n = -1console.log(`需求三:${data3.n},設置為 -1 失敗`)data3.n = 1console.log(`需求三:${data3.n},設置為 1 成功`)

可是如果不想用代理,要怎么做呢?

let myData = {n:0}let data4 = proxy({ data:myData }) // 括號里是匿名對象,無法訪問// data3 就是 objconsole.log(`杠精:${data4.n}`)//0myData.n = -1console.log(`杠精:${data4.n},設置為 -1 失敗了嗎!?`)

現(xiàn)在這樣還是能更改myData,所以我們又有一個需求:就算是用戶擅自修改myData,也要攔截:

let myData5 = {n:0}let data5 = proxy2({ data:myData5 }) // 括號里是匿名對象,無法訪問function proxy2({data}){ // 這里的 ’n’ 寫死了,理論上應該遍歷 data 的所有 key,這里做了簡化 let value = data.n//保存開始的n Object.defineProperty(data, ’n’, {//聲明一個新的n get(){ return value }, set(newValue){ if(newValue<0)return value = newValue } })

就加了上面幾句,這幾句話會監(jiān)聽 data

const obj = {} Object.defineProperty(obj, ’n’, { get(){ return data.n }, set(value){ if(value<0)return//這句話多余了 data.n = value } }) return obj // obj 就是代理}// data3 就是 objconsole.log(`需求五:${data5.n}`)//0myData5.n = -1console.log(`需求五:${data5.n},設置為 -1 失敗了`)//0myData5.n = 1console.log(`需求五:${data5.n},設置為 1 成功了`)//1

當我們寫vm = new Vue({data:myData})時,Vue做了兩件事情:

讓vm成為myData的代理(proxy),可以通過this訪問vm 會對myData所有的屬性進行監(jiān)控,為了防止myData的屬性變了,vm卻不知道,知道了屬性變化之后就可以調用render(data),UI就可以自動刷新

那么我們就可以回到標題了,什么是數(shù)據(jù)響應式呢?如果一個物體能夠對外界的刺激做出反應,那么它就是響應式的。Vue的data是響應式的,const vm = new Vue({data:{n:0}})在這個代碼中如果修改vm.n那么UI中的n就會做出相應的更新,Vue通過Object.defineProperty來實現(xiàn)數(shù)據(jù)響應式。響應式網(wǎng)頁又是什么呢?即如果改變窗口的大小,網(wǎng)頁內容會做出相應的改變,那么這個網(wǎng)頁就叫響應式網(wǎng)頁。

以上就是Vue 數(shù)據(jù)響應式相關總結的詳細內容,更多關于Vue 數(shù)據(jù)響應式的資料請關注好吧啦網(wǎng)其它相關文章!

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
精品在线播放| 国产精品久久久久久久久久10秀 | 99久久www免费| 日韩欧美不卡| 国产精品久久久久av电视剧| 日韩不卡免费高清视频| 日韩精品久久久久久久电影99爱| 国产成人精品亚洲日本在线观看| 久久精品二区三区| 99riav国产精品| 免费黄网站欧美| 欧美日一区二区三区在线观看国产免 | 国产成人免费精品| 精品国产aⅴ| 日韩精品dvd| 91精品久久久久久久久久不卡| 久久精品成人| 蜜桃一区二区三区在线| 91精品日本| 久久av网站| 日韩黄色大片| 国产精品美女| 欧美日本不卡高清| 国产美女高潮在线| 国产亚洲一级| 欧美久久一区二区三区| 福利在线一区| 亚洲视频www| 欧美在线观看天堂一区二区三区| 国产一区日韩| 欧美特黄一级大片| 蜜桃av一区二区| 国产精品v一区二区三区| 亚洲午夜天堂| 一级欧美视频| 国产一区2区| 丝袜亚洲另类欧美| 欧美国产亚洲精品| 91久久国产| 国产日韩欧美一区二区三区在线观看| 老牛影视精品| 亚洲婷婷丁香| 中国字幕a在线看韩国电影| 亚洲视频播放| 精品在线网站观看| 亚洲免费成人| 国产精品激情| 午夜日韩av| 国产精品theporn| 久久久精品五月天| 国产欧美一区二区三区国产幕精品| www.九色在线| 中文字幕亚洲影视| bbw在线视频| 日韩在线网址| 亚洲成人国产| 国产精品一二| 性欧美精品高清| 国产高潮在线| 91精品日本| 亚洲一区二区三区四区五区午夜| 国产精品久久免费视频| 亚洲欧美日韩精品一区二区| 成人精品久久| 亚洲免费毛片| 欧美日韩在线观看视频小说| 国产精品成人国产| 丝袜美腿亚洲一区| 黑森林国产精品av| 欧美私人啪啪vps| 亚洲成人日韩| 国产精品成久久久久| 日本不卡中文字幕| 亚洲激情中文| 日韩福利一区| 美女精品视频在线| 日本欧美在线看| 久久视频国产| 久久久精品国产**网站| 美美哒免费高清在线观看视频一区二区| 久久男人天堂| 国产欧美日韩精品一区二区免费 | 日韩精品中文字幕一区二区| 久久五月天小说| 精品99在线| 日本va欧美va瓶| 蜜桃一区二区三区在线观看| 国产亚洲永久域名| 欧洲激情综合| 丝袜美腿诱惑一区二区三区| 开心激情综合| 国产欧美一区二区三区米奇| 亚久久调教视频| 亚洲尤物在线| 极品日韩av| 日本美女一区| 国模大尺度视频一区二区| 国产精品白丝一区二区三区| 欧美日本不卡| 中文字幕亚洲影视| 久久福利精品| 影院欧美亚洲| 免费国产自久久久久三四区久久| 欧美1区二区| 国产亚洲久久| 欧美日韩一区二区三区在线电影| 亚洲精品在线a| 蜜臀av性久久久久蜜臀aⅴ流畅| 亚洲一区欧美二区| 香蕉久久久久久久av网站| 亚洲一区二区三区高清不卡| 蘑菇福利视频一区播放| 99热精品在线| 亚洲欧美网站| 免费不卡在线观看| 蜜臀va亚洲va欧美va天堂| 日本欧美在线看| 亚洲毛片一区| 日本欧美一区| 欧美交a欧美精品喷水| 嫩呦国产一区二区三区av| 精品网站999| sm久久捆绑调教精品一区| 伊人久久国产| 久久精品不卡| 欧美另类综合| 视频一区欧美精品| 日韩区一区二| 国产麻豆一区二区三区精品视频| 久久国产麻豆精品| 欧美片网站免费| 美女视频一区在线观看| 成人精品国产亚洲| 久久天堂av| 一区二区自拍| 视频一区中文字幕精品| 欧美一区久久| 久草精品视频| 亚洲不卡av不卡一区二区| 午夜国产欧美理论在线播放| 视频一区中文字幕| 欧美日韩一区二区三区不卡视频 | 午夜av成人| 亚洲欧美视频| 清纯唯美亚洲综合一区| 久久中文精品| 国产精品字幕| 视频一区二区三区中文字幕| 日本午夜精品久久久| 狠狠久久伊人| 不卡视频在线| 日本欧美一区| 另类专区亚洲| 日韩一级网站| 日韩av影院| 成午夜精品一区二区三区软件| 国产99精品一区| 一级成人国产| 国产精品不卡| 丝袜美腿亚洲色图| 免费日韩一区二区三区| 91精品啪在线观看国产18| 三级一区在线视频先锋| 国产精品网站在线看| 欧美日韩精品免费观看视欧美高清免费大片 | 91精品啪在线观看国产18| 视频一区国产视频| 精品一级视频| 老色鬼久久亚洲一区二区| 国产精品久久久久久久免费软件| 亚洲深夜视频| 亚洲日本国产| 中文在线а√在线8| 中文字幕亚洲影视| www在线观看黄色| 亚洲字幕久久| 丁香六月综合| 视频一区日韩精品| 天堂√8在线中文| 亚洲欧洲av| 成人在线观看免费视频| 免费在线看一区| 成人国产精选| 亚洲精品伊人| 日韩理论片av| 欧美日韩精品一区二区三区视频 | 一区二区三区视频免费观看| 日韩精品免费一区二区夜夜嗨| 国产白浆在线免费观看| 亚洲精品成a人ⅴ香蕉片| 欧美日韩国产v| 欧美啪啪一区| 亚洲一区不卡| 97精品国产| 日韩精品亚洲专区| 影视先锋久久| 精品五月天堂| 日本午夜精品一区二区三区电影| 136国产福利精品导航网址| 国产欧美一区二区色老头|