Vue計(jì)算屬性與監(jiān)視(偵聽)屬性的使用深度學(xué)習(xí)
計(jì)算屬性(computed)
計(jì)算屬性指的是通過一系列運(yùn)算之后,最終得到一個(gè)值。這個(gè)動(dòng)態(tài)計(jì)算出來的屬性值可以被模板結(jié)構(gòu)或methods方法使用,案例如下:
<div id="root"> R:<input type="text" v-model.number="r"><br> G:<input type="text" v-model.number="g"><br> B:<input type="text" v-model.number="b"> <div class="box" :style="{backgroundColor:rgb}"> {{rgb}} </div> <button @click="show">按鈕</button> </div> <script src="/vue/vue.js"></script> <script> const vm = new Vue({ el:'#root', data:{ r:0 , g:0, b:0, }, methods: { show() { console.log(this.rgb); } }, //所有計(jì)算屬性都要定義到computed節(jié)點(diǎn)之下 computed: { // 計(jì)算屬性在定義的時(shí)候,要定義成“方法格式”,在這個(gè)方法中會(huì)生成好的rgb(x,x,x)的字符串 //實(shí)現(xiàn)了代碼的復(fù)用,只要計(jì)算屬性中依賴的數(shù)據(jù)變化了,則計(jì)算屬性會(huì)自動(dòng)重新賦值 rgb() { return `rgb(${this.r},${this.g},${this.b})` } } }) </script>
使用名字動(dòng)態(tài)改變實(shí)現(xiàn)計(jì)算屬性案例:
<div id="root"> <input type="text" v-model="firstname"><br> <input type="text" v-model="lastname"><br> 全名:<span>{{fullname}}</span> </div> <script src="/vue/vue.js"></script> <script> const vm = new Vue({ el:"#root", data:{ firstname:'張', lastname:'三' }, computed:{ fullname:{ //當(dāng)初次讀取fullname或所依賴的數(shù)據(jù)發(fā)生變化時(shí),get被調(diào)用 get(){ console.log('get被調(diào)用了'); return this.firstname+'-'+this.lastname }, //當(dāng)主動(dòng)修改fullname時(shí),set被調(diào)用 set(value){ console.log('set', value); const arr = value.split('-'); this.firstname = arr[0] this.lastname = arr[1] } } } }) </script>
計(jì)算屬性:
1.定義:要用的屬性不存在,要通過已有的屬性得來
2.原理:底層借助了Object.defineproperty方法提供的getter和setter
3.優(yōu)勢(shì):與methods實(shí)現(xiàn)相比,內(nèi)部有緩存機(jī)制(復(fù)用),效率更高,調(diào)試方便
4.備注:計(jì)算屬性最終會(huì)出現(xiàn)在vm上,直接讀取使用即可;如果計(jì)算屬性要被修改,那必須寫set函數(shù)去響應(yīng)改變,且set中要引起計(jì)算時(shí)依賴的數(shù)據(jù)發(fā)生改變。
監(jiān)視屬性(watch)
watch監(jiān)視(偵聽)器允許開發(fā)者監(jiān)視數(shù)據(jù)的變化,從而針對(duì)數(shù)據(jù)的變化做特定的操作。
監(jiān)視的兩種方法
通過new Vue時(shí)傳入watch配置:
<div id="root"> <input type="text" v-model="name"> </div> <script src="./vue.js"></script> <script> const vm = new Vue({ el:'#root', data:{ name:'' }, //所有的偵聽器,都應(yīng)該被定義到watch節(jié)點(diǎn)下 watch:{ // 偵聽器本質(zhì)上是一個(gè)函數(shù),要監(jiān)視哪個(gè)數(shù)據(jù)的變化,就把數(shù)據(jù)名作為方法名即可 //newVal是“變化后的新值”,oldVal是“變化之前舊值” name(newVal,oldVal){ //監(jiān)聽name值的變化 console.log("監(jiān)聽到了新值"+newVal, "監(jiān)聽到了舊值"+oldVal); } } }) </script>
通過vm.$watch監(jiān)視:
<div id="root"> <h2>今天天氣很{{info}}</h2> <button @click="changeWeather">切換天氣</button> </div> <script src="./vue.js"></script> <script> const vm = new Vue({ el:'#root', data:{ isHot:true }, computed:{ info(){ return this.isHot ? '炎熱' : '涼爽' } }, methods:{ changeWeather(){ this.isHot = !this.isHot } }, }) vm.$watch('info',{ handler(newVal,oldVal){ console.log('天氣被修改了', newVal, oldVal); } }) </script>
immediate選項(xiàng)
默認(rèn)情況下,組件在初次加載完畢后不會(huì)調(diào)用watch偵聽器,如果想讓watch偵聽器立即被調(diào)用,則需要使用immediate選項(xiàng),immediate的作用是控制偵聽器是否自動(dòng)觸發(fā)一次,選項(xiàng)的默認(rèn)值為:false
<div id="root"> <input type="text" v-model="name"> </div> <script src="./vue.js"></script> <script> const vm = new Vue({ el:'#root', data:{ name:'admin' }, watch:{ //定義對(duì)象格式的偵聽器 name:{ handler(newVal,oldVal){ console.log(newVal, oldVal); }, immediate:true } } }) </script>
深度監(jiān)視
如果watch偵聽的是一個(gè)對(duì)象,如果對(duì)象中的屬性值發(fā)生了變化,則無法被監(jiān)聽到。此時(shí)需要使用deep選項(xiàng),開啟深度監(jiān)聽,只要對(duì)象中任何一個(gè)屬性變化了,都會(huì)觸發(fā)“對(duì)象的偵聽器”。
<div id="root"> <input type="text" v-model="info.name"> </div> <script src="./vue.js"></script> <script> const vm = new Vue({ el:'#root', data:{ info:{ name:'admin' } }, watch:{ info: { handler(newVal){ console.log(newVal); }, //開啟深度監(jiān)聽 deep:true } } }) </script>
如果想要偵聽的對(duì)象是子屬性的變化,則必須包裹一層單引號(hào)。
watch:{ "info.name"(newVal){ console.log(newVal); } }
總結(jié):
1)Vue中的watch默認(rèn)不監(jiān)測(cè)對(duì)象內(nèi)部值的改變(一層)
2)配置deep:true可以監(jiān)測(cè)對(duì)象內(nèi)部值改變(多層)
3)Vue自身可以監(jiān)測(cè)對(duì)象內(nèi)部值的改變,但Vue提供的watch默認(rèn)不可以
4)使用watch時(shí)根據(jù)數(shù)據(jù)的具體結(jié)構(gòu),決定是否采用深度監(jiān)視
watch能開啟異步任務(wù),案例如下:
<div id="root"> <input type="text" v-model="firstname"><br> <input type="text" v-model="lastname"><br> 全名:<span>{{fullname}}</span> </div> <script src="/vue/vue.js"></script> <script> const vm = new Vue({ el:"#root", data:{ firstname:'張', lastname:'三', fullname:'張-三' }, //watch能開啟異步任務(wù) watch:{ firstname(val){ setTimeout(()=>{ this.fullname = val + '-' + this.lastname },1000) }, lastname(val){ this.fullname = this.firstname+'-'+val } } }) </script>
computed和watch之間的區(qū)別:
1.computed能完成的功能,watch都可以完成。
2.watch能完成的功能,computed不一定能完成,例如:watch可以進(jìn)行異步操作。
隱性原則:
1.被Vue管理的函數(shù),最好寫成普通函數(shù),這樣this的指向才是vm或組件實(shí)例對(duì)象
2.不被Vue所管理的函數(shù)(定時(shí)器的回調(diào)函數(shù)、ajax的回調(diào)函數(shù)、Promise的回調(diào)函數(shù)),最好寫成箭頭函數(shù),這樣this的指向才是vm或組件實(shí)例對(duì)象。
到此這篇關(guān)于Vue計(jì)算屬性與監(jiān)視(偵聽)屬性的使用的文章就介紹到這了,更多相關(guān)vue計(jì)算屬性和偵聽屬性內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue3+vite中開發(fā)環(huán)境與生產(chǎn)環(huán)境全局變量配置指南
最近在使用vite生成項(xiàng)目,這篇文章主要給大家介紹了關(guān)于vue3+vite中開發(fā)環(huán)境與生產(chǎn)環(huán)境全局變量配置的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08Vue+Element UI 實(shí)現(xiàn)視頻上傳功能
這篇文章主要介紹了Vue+Element UI 實(shí)現(xiàn)視頻上傳功能,前臺(tái)使用Vue+Element UI中的el-upload組件實(shí)現(xiàn)視頻上傳及進(jìn)度條展示,后臺(tái)提供視頻上傳API并返回URL,具體實(shí)現(xiàn)代碼及效果展示跟隨小編一起看看吧2022-01-01Vue封裝DateRangePicker組件流程詳細(xì)介紹
在后端管理項(xiàng)目中使用vue來進(jìn)行前端項(xiàng)目的開發(fā),但我們都知道Vue實(shí)際上無法監(jiān)聽由第三方插件所引起的數(shù)據(jù)變化。也無法獲得JQuery這樣的js框架對(duì)元素值的修改的。而日期控件daterangepicker又基于JQuery來實(shí)現(xiàn)的2022-11-11vue實(shí)現(xiàn)滑動(dòng)超出指定距離回頂部功能
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)滑動(dòng)超出指定距離回頂部功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07Vue中使用Printjs插件實(shí)現(xiàn)打印功能
Print.js 主要是為了幫助我們直接在我們的應(yīng)用程序中打印 PDF 文件,無需離開界面,也無需使用嵌入,這篇文章主要介紹了Vue中使用Printjs插件實(shí)現(xiàn)打印功能,需要的朋友可以參考下2022-08-08vue項(xiàng)目main.js使用方法詳細(xì)介紹
這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目main.js使用方法的相關(guān)資料,main.js文件是程序的入口文件,加載各種公共組件,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-09-09Vue+ElementUI 中級(jí)聯(lián)選擇器Bug問題的解決
這篇文章主要介紹了Vue+ElementUI 中級(jí)聯(lián)選擇器Bug問題的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-07-07element-ui?table表格底部合計(jì)自定義配置過程
這篇文章主要介紹了element-ui?table表格底部合計(jì)自定義配置過程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10