欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue計(jì)算屬性與監(jiān)視屬性詳細(xì)分析使用

 更新時間:2022年11月07日 14:17:25   作者:亦世凡華、  
computed是vue的配置選項(xiàng),它的值是一個對象,其中可定義多個計(jì)算屬性,每個計(jì)算屬性就是一個函數(shù),下面這篇文章主要給大家介紹了關(guān)于vue中計(jì)算屬性computed的詳細(xì)講解,需要的朋友可以參考下

計(jì)算屬性(computed)

計(jì)算屬性指的是通過一系列運(yùn)算之后,最終得到一個值。這個動態(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ì)算屬性在定義的時候,要定義成“方法格式”,在這個方法中會生成好的rgb(x,x,x)的字符串
            //實(shí)現(xiàn)了代碼的復(fù)用,只要計(jì)算屬性中依賴的數(shù)據(jù)變化了,則計(jì)算屬性會自動重新賦值
            rgb() {
                return `rgb(${this.r},${this.g},${this.b})`
            }
        }
    })
</script>

使用名字動態(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ā)生變化時,get被調(diào)用
                get(){
                    console.log('get被調(diào)用了');
                    return this.firstname+'-'+this.lastname
                },
                //當(dāng)主動修改fullname時,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)勢:與methods實(shí)現(xiàn)相比,內(nèi)部有緩存機(jī)制(復(fù)用),效率更高,調(diào)試方便

4.備注:計(jì)算屬性最終會出現(xiàn)在vm上,直接讀取使用即可;如果計(jì)算屬性要被修改,那必須寫set函數(shù)去響應(yīng)改變,且set中要引起計(jì)算時依賴的數(shù)據(jù)發(fā)生改變。

監(jiān)視屬性(watch)

watch監(jiān)視(偵聽)器允許開發(fā)者監(jiān)視數(shù)據(jù)的變化,從而針對數(shù)據(jù)的變化做特定的操作。

監(jiān)視的兩種方法

通過new Vue時傳入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ì)上是一個函數(shù),要監(jiān)視哪個數(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)情況下,組件在初次加載完畢后不會調(diào)用watch偵 聽 器,如果想讓watch偵 聽 器立即被調(diào)用,則需要使用immediate選項(xiàng),immediate的作用是控制偵 聽 器是否自動觸發(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:{
            //定義對象格式的偵 聽 器
            name:{
                handler(newVal,oldVal){
                    console.log(newVal, oldVal);
                },
                immediate:true
            }
        }
    })
</script>

深度監(jiān)視

如果watch偵聽的是一個對象,如果對象中的屬性值發(fā)生了變化,則無法被監(jiān)聽到。此時需要使用deep選項(xiàng),開啟深度監(jiān)聽,只要對象中任何一個屬性變化了,都會觸發(fā)“對象的偵 聽 器”。

<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>

如果想要偵聽的對象是子屬性的變化,則必須包裹一層單引號。

watch:{
    "info.name"(newVal){
        console.log(newVal);
    }
}

總結(jié):

1)Vue中的watch默認(rèn)不監(jiān)測對象內(nèi)部值的改變(一層)

2)配置deep:true可以監(jiān)測對象內(nèi)部值改變(多層)

3)Vue自身可以監(jiān)測對象內(nèi)部值的改變,但Vue提供的watch默認(rèn)不可以

4)使用watch時根據(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í)例對象

2.不被Vue所管理的函數(shù)(定時器的回調(diào)函數(shù)、ajax的回調(diào)函數(shù)、Promise的回調(diào)函數(shù)),最好寫成箭頭函數(shù),這樣this的指向才是vm或組件實(shí)例對象。

到此這篇關(guān)于Vue計(jì)算屬性與監(jiān)視屬性詳細(xì)分析使用的文章就介紹到這了,更多相關(guān)Vue計(jì)算屬性與監(jiān)視屬性內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue安裝與使用

    Vue安裝與使用

    Vue是一套用于構(gòu)建前后端分離的框架。剛開始是由國內(nèi)優(yōu)秀選手尤雨溪開發(fā)出來的,目前是全球“最”流行的前端框架。使用vue開發(fā)網(wǎng)頁很簡單,并且技術(shù)生態(tài)環(huán)境完善,社區(qū)活躍,是前后端找工作必備技能!下面來看看其得安裝及使用方法吧
    2021-10-10
  • vue中SPA單頁面應(yīng)用程序詳解

    vue中SPA單頁面應(yīng)用程序詳解

    這篇文章主要為大家詳細(xì)介紹了vue中SPA單頁面應(yīng)用程序的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • Vue組件封裝上傳圖片和視頻的示例代碼

    Vue組件封裝上傳圖片和視頻的示例代碼

    這篇文章主要介紹了Vue封裝上傳圖片和視頻的組件,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-07-07
  • Vue?Vuex搭建vuex環(huán)境及vuex求和案例分享

    Vue?Vuex搭建vuex環(huán)境及vuex求和案例分享

    這篇文章主要介紹了Vue?Vuex搭建vuex環(huán)境及vuex求和案例分享,?Vue?中實(shí)現(xiàn)集中式狀態(tài)管理的一個?Vue?插件,對?vue?應(yīng)用中多個組件的共享狀態(tài)進(jìn)行集中式的管理,下文相關(guān)介紹,需要的朋友可以參考一下
    2022-04-04
  • vue報錯"vue-cli-service‘不是內(nèi)部或外部命令,也不是...”的解決辦法

    vue報錯"vue-cli-service‘不是內(nèi)部或外部命令,也不是...”的解決辦法

    這篇文章主要介紹了vue報錯"vue-cli-service‘不是內(nèi)部或外部命令,也不是...”的解決辦法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-01-01
  • vue3+vite項(xiàng)目中按需引入vant報錯:Failed?to?resolve?import的解決方案

    vue3+vite項(xiàng)目中按需引入vant報錯:Failed?to?resolve?import的解決方案

    最近在vue項(xiàng)目中引入vant的時候發(fā)現(xiàn)報錯了,經(jīng)過嘗試發(fā)現(xiàn)了問題,現(xiàn)將完整引入流程提供給大家參考,下面這篇文章主要給大家介紹了關(guān)于vue3+vite項(xiàng)目中按需引入vant報錯:Failed?to?resolve?import的解決方案,需要的朋友可以參考下
    2022-12-12
  • Vue子組件調(diào)用父組件方法案例詳解

    Vue子組件調(diào)用父組件方法案例詳解

    這篇文章主要介紹了Vue子組件調(diào)用父組件方法案例詳解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-09-09
  • Vue使用Less與Scss實(shí)現(xiàn)主題切換方法詳細(xì)講解

    Vue使用Less與Scss實(shí)現(xiàn)主題切換方法詳細(xì)講解

    目前,在眾多的后臺管理系統(tǒng)中,換膚功能已是一個很常見的功能。用戶可以根據(jù)自己的喜好,設(shè)置頁面的主題,從而實(shí)現(xiàn)個性化定制。目前,我所了解到的換膚方式,也是我目前所掌握的兩種換膚方式,想同大家一起分享
    2023-02-02
  • vue-admin如何實(shí)現(xiàn)動態(tài)路由

    vue-admin如何實(shí)現(xiàn)動態(tài)路由

    這篇文章主要介紹了vue-admin如何實(shí)現(xiàn)動態(tài)路由問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • 高頻率Vue面試題匯總以及答案

    高頻率Vue面試題匯總以及答案

    vue是組件化開發(fā)框架,所以對于vue應(yīng)用來說組件間的數(shù)據(jù)通信非常重要,下面這篇文章主要給大家介紹了關(guān)于高頻率Vue面試題以及答案的相關(guān)資料,需要的朋友可以參考下
    2023-02-02

最新評論