亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue.js?的計(jì)算屬性和偵聽器詳解(提升數(shù)據(jù)處理與交互的關(guān)鍵工具)

 更新時(shí)間:2025年04月10日 12:24:09   作者:予安靈  
在Vue.js開發(fā)中,計(jì)算屬性與偵聽器是極為關(guān)鍵的特性,它們極大地提升了數(shù)據(jù)處理與交互邏輯實(shí)現(xiàn)的便捷性和高效性,本文給大家介紹Vue.js?的計(jì)算屬性和偵聽器:提升數(shù)據(jù)處理與交互的關(guān)鍵工具,感興趣的朋友一起看看吧

引言

在Vue.js的編程世界里,構(gòu)建高效且交互豐富的應(yīng)用離不開對數(shù)據(jù)的精準(zhǔn)把控與靈活處理。其中,計(jì)算屬性與偵聽器作為數(shù)據(jù)處理的得力助手,發(fā)揮著舉足輕重的作用。

計(jì)算屬性憑借其獨(dú)特的緩存機(jī)制,能巧妙地應(yīng)對復(fù)雜數(shù)據(jù)計(jì)算,讓開發(fā)者從繁瑣的重復(fù)運(yùn)算中解脫出來;偵聽器則如同敏銳的觀察者,時(shí)刻留意數(shù)據(jù)的動態(tài)變化,適時(shí)觸發(fā)相應(yīng)操作,為應(yīng)用注入靈動的交互邏輯。接下來,讓我們一同深入《Vue.js快速入門實(shí)戰(zhàn)》中關(guān)于計(jì)算屬性和偵聽器的章節(jié),全面解鎖它們的奧秘,探尋如何運(yùn)用這些強(qiáng)大特性,打造出更具魅力與效能的Vue.js應(yīng)用 。

1.計(jì)算屬性的定義

知識點(diǎn)介紹

計(jì)算屬性是 Vue.js 賦予開發(fā)者基于響應(yīng)式依賴進(jìn)行復(fù)雜計(jì)算的有力工具。它能緩存計(jì)算結(jié)果,僅當(dāng)相關(guān)依賴發(fā)生變化時(shí)才重新計(jì)算。這一特性使得在處理頻繁使用且計(jì)算成本較高的數(shù)據(jù)時(shí),性能得到顯著提升。

定義案例用法

在 Vue 實(shí)例的computed選項(xiàng)中定義計(jì)算屬性函數(shù)。以一個(gè)電商場景為例,假設(shè)有一個(gè)商品列表,每個(gè)商品對象包含price(價(jià)格)和quantity(數(shù)量)屬性,需要計(jì)算商品總價(jià)。首先在 Vue 組件的data選項(xiàng)中定義商品列表:

data() {
    return {
        products: [
            { id: 1, price: 10, quantity: 2 },
            { id: 2, price: 15, quantity: 3 }
        ]
    };
}

然后在computed選項(xiàng)中定義計(jì)算商品總價(jià)的計(jì)算屬性

computed: {
    totalPrice() {
        let total = 0;
        this.products.forEach(product => {
            total += product.price * product.quantity;
        });
        return total;
    }
}

在模板中,就可以像使用普通屬性一樣使用totalPrice

<div>商品總價(jià): {{ totalPrice }}</div>

當(dāng)products列表中的任何商品的pricequantity發(fā)生變化時(shí),totalPrice會自動重新計(jì)算。

2.計(jì)算屬性的用法

知識點(diǎn)介紹

通過computed定義的計(jì)算屬性極大地簡化了模板中的復(fù)雜邏輯,顯著提升了代碼的可讀性和可維護(hù)性。由于其緩存機(jī)制,相比每次都執(zhí)行的普通方法調(diào)用,計(jì)算屬性在性能上更具優(yōu)勢,尤其是在依賴數(shù)據(jù)未發(fā)生變化時(shí),直接返回緩存結(jié)果,避免了重復(fù)計(jì)算。

用法

在 Vue 組件的computed對象中編寫方法,方法內(nèi)部依據(jù)依賴的響應(yīng)式數(shù)據(jù)進(jìn)行計(jì)算并返回結(jié)果,在模板中直接使用該計(jì)算屬性名。例如,有一個(gè)包含用戶信息的對象user,其中有firstNamelastName屬性,需要在頁面上顯示完整姓名。在data選項(xiàng)中定義user對象:

data() {
    return {
        user: {
            firstName: 'John',
            lastName: 'Doe'
        }
    };
}

computed選項(xiàng)中定義計(jì)算完整姓名的屬性:

computed: {
    fullName() {
        return this.user.firstName +'' + this.user.lastName;
    }
}

在模板中使用:

<div>用戶姓名: {{ fullName }}</div>

這樣,模板中無需編寫復(fù)雜的字符串拼接邏輯,使代碼更簡潔清晰。

3. 計(jì)算屬性的緩存

知識點(diǎn)介紹

計(jì)算屬性的緩存機(jī)制是其核心優(yōu)勢之一。它會記住計(jì)算結(jié)果,只要依賴的數(shù)據(jù)沒有改變,就不會重新計(jì)算。這與普通方法調(diào)用每次都會執(zhí)行的行為截然不同,在復(fù)雜計(jì)算場景下,能極大提升性能。例如,一個(gè)計(jì)算屬性依賴于多個(gè)響應(yīng)式數(shù)據(jù),且計(jì)算過程涉及大量數(shù)據(jù)處理和復(fù)雜算法,若每次訪問都重新計(jì)算,會嚴(yán)重影響應(yīng)用的響應(yīng)速度。而計(jì)算屬性的緩存機(jī)制確保了在依賴數(shù)據(jù)不變時(shí),直接返回之前計(jì)算好的結(jié)果,減少了不必要的計(jì)算開銷。

用法案例

開發(fā)者只需按照常規(guī)方式定義計(jì)算屬性,Vue 會自動處理緩存邏輯,無需手動干預(yù)。

以一個(gè)實(shí)時(shí)匯率轉(zhuǎn)換的場景為例,假設(shè)有一個(gè)exchangeRate(匯率)和amount(金額)的響應(yīng)式數(shù)據(jù),需要計(jì)算轉(zhuǎn)換后的金額。在data選項(xiàng)中定義數(shù)據(jù):

data() {
    return {
        exchangeRate: 6.5,
        amount: 100
    };
}

computed選項(xiàng)中定義計(jì)算轉(zhuǎn)換后金額的屬性:

computed: {
    convertedAmount() {
        return this.amount * this.exchangeRate;
    }
}

只要exchangeRateamount沒有變化,每次訪問convertedAmount時(shí),都會直接返回緩存的結(jié)果,而不會重新執(zhí)行乘法運(yùn)算。

4. 偵聽屬性的定義

知識點(diǎn)介紹

偵聽器(watch)用于監(jiān)聽數(shù)據(jù)的變化,并在數(shù)據(jù)變化時(shí)觸發(fā)相應(yīng)的回調(diào)函數(shù)。這一特性在需要處理異步操作、復(fù)雜業(yè)務(wù)邏輯等場景中極為有用。例如,當(dāng)用戶在輸入框中輸入搜索關(guān)鍵詞后,需要立即發(fā)起網(wǎng)絡(luò)請求獲取相關(guān)搜索結(jié)果,就可以使用偵聽器來監(jiān)聽輸入框綁定的數(shù)據(jù)變化,并在變化時(shí)執(zhí)行網(wǎng)絡(luò)請求操作。

用法案例

在 Vue 實(shí)例的watch選項(xiàng)中定義偵聽函數(shù),明確指定要監(jiān)聽的數(shù)據(jù)以及數(shù)據(jù)變化時(shí)執(zhí)行的操作。例如,有一個(gè)用于搜索商品的輸入框,其綁定的數(shù)據(jù)為searchKeyword,在data選項(xiàng)中定義:

data() {
    return {
        searchKeyword: ''
    };
}

watch選項(xiàng)中定義偵聽函數(shù):

watch: {
    searchKeyword(newValue, oldValue) {
        if (newValue.trim()!== '') {
            // 這里可以發(fā)起網(wǎng)絡(luò)請求,根據(jù)newValue進(jìn)行商品搜索
            console.log('搜索關(guān)鍵詞已改變,新關(guān)鍵詞為:', newValue);
        }
    }
}

當(dāng)searchKeyword的值發(fā)生變化時(shí),偵聽函數(shù)會被調(diào)用,新值和舊值會作為參數(shù)傳遞給函數(shù),開發(fā)者可在函數(shù)內(nèi)部編寫相應(yīng)的業(yè)務(wù)邏輯。

5.偵聽屬性的用法

知識點(diǎn)介紹

偵聽器不僅能監(jiān)聽基本數(shù)據(jù)類型的變化,還可以通過設(shè)置deep: true來深度偵聽對象內(nèi)部屬性的變化。此外,設(shè)置immediate: true可使偵聽器在綁定后立即執(zhí)行一次,這在某些需要初始化數(shù)據(jù)或在數(shù)據(jù)加載后立即執(zhí)行特定邏輯的場景中非常實(shí)用。偵聽器適用于在數(shù)據(jù)變化時(shí)執(zhí)行副作用操作,如網(wǎng)絡(luò)請求、數(shù)據(jù)持久化到本地存儲等場景。

用法案例

深度偵聽

假設(shè)在data中有一個(gè)復(fù)雜的user對象,包含多個(gè)嵌套屬性,如user.address.city,需要監(jiān)聽city屬性的變化。定義datawatch如下:

data() {
    return {
        user: {
            address: {
                city: 'New York'
            }
        }
    };
}
watch: {
    user: {
        handler(newValue, oldValue) {
            console.log('用戶地址的城市已改變,新城市為:', newValue.address.city);
        },
        deep: true
    }
}

這樣,當(dāng)user.address.city的值發(fā)生變化時(shí),偵聽函數(shù)會被觸發(fā)。

立即執(zhí)行

若希望在組件加載時(shí)就執(zhí)行一次偵聽函數(shù),對數(shù)據(jù)進(jìn)行初始化處理。以監(jiān)聽isLoggedIn(表示用戶登錄狀態(tài))為例:

data() {
    return {
        isLoggedIn: false
    };
}
watch: {
    isLoggedIn: {
        handler(newValue) {
            if (newValue) {
                // 加載用戶信息等初始化操作
                console.log('用戶已登錄,執(zhí)行初始化操作');
            }
        },
        immediate: true
    }
}

組件加載時(shí),isLoggedIn的偵聽函數(shù)會立即執(zhí)行一次。

6.實(shí)戰(zhàn):制作一個(gè)點(diǎn)擊頁面

知識點(diǎn)介紹

本實(shí)戰(zhàn)案例融合了前面所學(xué)的計(jì)算屬性和偵聽器知識,展示了如何在 Vue 項(xiàng)目中創(chuàng)建具有交互功能的頁面。通過實(shí)際操作,進(jìn)一步理解數(shù)據(jù)綁定、事件處理以及計(jì)算屬性和偵聽器在構(gòu)建交互式頁面中的協(xié)同作用。

用法案例

假設(shè)要制作一個(gè)點(diǎn)擊頁面,頁面上有一個(gè)計(jì)數(shù)器,每次點(diǎn)擊按鈕,計(jì)數(shù)器增加,同時(shí)根據(jù)計(jì)數(shù)器的值顯示不同的文本信息,并且當(dāng)計(jì)數(shù)器達(dá)到一定值時(shí),觸發(fā)一個(gè)特殊操作。在 Vue 組件中,首先在data選項(xiàng)中定義數(shù)據(jù):

data() {
    return {
        count: 0,
        message: '初始信息'
    };
}

然后在computed選項(xiàng)中定義一個(gè)計(jì)算屬性,根據(jù)count的值生成不同的message

computed: {
    displayMessage() {
        if (this.count < 5) {
            return '點(diǎn)擊次數(shù)較少';
        } else if (this.count < 10) {
            return '點(diǎn)擊次數(shù)中等';
        } else {
            return '點(diǎn)擊次數(shù)較多';
        }
    }
}

在模板中,綁定按鈕的點(diǎn)擊事件,增加count的值,并顯示displayMessage

<button @click="count++">點(diǎn)擊我</button>
<div>{{ displayMessage }}</div>

接著,使用偵聽器來處理當(dāng)count達(dá)到 10 時(shí)的特殊操作,比如顯示一個(gè)提示框:

watch: {
    count(newValue) {
        if (newValue === 10) {
            alert('點(diǎn)擊次數(shù)已達(dá)到10次!');
        }
    }
}

通過這樣的方式,綜合運(yùn)用計(jì)算屬性和偵聽器,實(shí)現(xiàn)了一個(gè)具有豐富交互功能的點(diǎn)擊頁面,加深了對 Vue.js 相關(guān)知識的理解和應(yīng)用能力。

總結(jié)

在Vue.js開發(fā)中,計(jì)算屬性與偵聽器是極為關(guān)鍵的特性,它們極大地提升了數(shù)據(jù)處理與交互邏輯實(shí)現(xiàn)的便捷性和高效性。 計(jì)算屬性憑借緩存機(jī)制,有效規(guī)避了復(fù)雜數(shù)據(jù)計(jì)算的重復(fù)操作,顯著提升性能。

在電商場景中計(jì)算商品總價(jià),或是處理用戶信息展示時(shí),它簡化了模板邏輯,增強(qiáng)了代碼的可讀性與可維護(hù)性。開發(fā)者只需在`computed`選項(xiàng)中依循響應(yīng)式依賴編寫計(jì)算邏輯,Vue.js便會自動管理緩存,無需手動干預(yù),這在頻繁使用且計(jì)算成本高的數(shù)據(jù)處理場景中優(yōu)勢盡顯。 偵聽器則專注于監(jiān)聽數(shù)據(jù)變化,能在數(shù)據(jù)變動時(shí)觸發(fā)相應(yīng)回調(diào),為異步操作與復(fù)雜業(yè)務(wù)邏輯處理提供了有力支持。無論是監(jiān)聽用戶輸入以發(fā)起搜索請求,還是深度監(jiān)聽復(fù)雜對象內(nèi)部屬性變化,亦或是在組件加載時(shí)立即執(zhí)行特定邏輯,偵聽器都能精準(zhǔn)滿足需求。

通過`watch`選項(xiàng),開發(fā)者可靈活定義監(jiān)聽規(guī)則與響應(yīng)行為,極大地豐富了應(yīng)用的交互性。 在實(shí)戰(zhàn)環(huán)節(jié),制作點(diǎn)擊頁面的案例充分展現(xiàn)了計(jì)算屬性與偵聽器的協(xié)同效能。根據(jù)計(jì)數(shù)器的值動態(tài)生成不同文本信息,借助計(jì)算屬性實(shí)現(xiàn);而在計(jì)數(shù)器達(dá)到特定值時(shí)觸發(fā)提示框,依靠偵聽器完成。這一過程不僅加深了對二者的理解,更凸顯了它們在構(gòu)建交互式頁面中的重要作用。 綜上所述,深入掌握計(jì)算屬性與偵聽器的使用方法,能助力開發(fā)者在Vue.js項(xiàng)目中更高效地處理數(shù)據(jù),構(gòu)建出交互豐富、性能卓越的Web應(yīng)用,為用戶帶來更優(yōu)質(zhì)的體驗(yàn)。

到此這篇關(guān)于Vue.js 的計(jì)算屬性和偵聽器:提升數(shù)據(jù)處理與交互的關(guān)鍵工具的文章就介紹到這了,更多相關(guān)Vue.js 計(jì)算屬性和偵聽器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue 如何使用vue-cropper裁剪圖片你知道嗎

    vue 如何使用vue-cropper裁剪圖片你知道嗎

    這篇文章主要為大家介紹了vue 使用vue-cropper裁剪圖片,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • Vue常用指令詳解分析

    Vue常用指令詳解分析

    這篇文章給大家詳細(xì)分析了關(guān)于VUE的常用的相關(guān)指令內(nèi)容,對此有需要的朋友們可以學(xué)習(xí)下。
    2018-08-08
  • vue3中虛擬dom的介紹與使用詳解

    vue3中虛擬dom的介紹與使用詳解

    Vue?是如何將一份模板轉(zhuǎn)換為真實(shí)的?DOM?節(jié)點(diǎn)的,又是如何高效地更新這些節(jié)點(diǎn)的呢,這些都離不開虛擬dom這個(gè)概念,下面我們就來了解下虛擬dom這個(gè)概念以及它是什么吧
    2024-01-01
  • 在Vue中實(shí)現(xiàn)隨hash改變響應(yīng)菜單高亮

    在Vue中實(shí)現(xiàn)隨hash改變響應(yīng)菜單高亮

    這篇文章主要介紹了在Vue中實(shí)現(xiàn)隨hash改變響應(yīng)菜單高亮的方法,文中還通過實(shí)例代碼給大家介紹了vue關(guān)于點(diǎn)擊菜單高亮與組件切換的相關(guān)知識,需要的朋友可以參考下
    2020-03-03
  • vue+axios 前端實(shí)現(xiàn)的常用攔截的代碼示例

    vue+axios 前端實(shí)現(xiàn)的常用攔截的代碼示例

    這篇文章主要介紹了vue+axios 前端實(shí)現(xiàn)的常用攔截的代碼示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-08-08
  • vue使用vue-video-player插件播放視頻的步驟講解

    vue使用vue-video-player插件播放視頻的步驟講解

    在最近的項(xiàng)目中有一個(gè)視頻播放的功能,在之前的項(xiàng)目中沒有接觸過類似的功能,第一次接觸,把具體操作步驟一下,這篇文章主要給大家介紹了關(guān)于vue使用vue-video-player插件播放視頻的相關(guān)資料,需要的朋友可以參考下
    2022-12-12
  • vue-cli構(gòu)建項(xiàng)目下使用微信分享功能

    vue-cli構(gòu)建項(xiàng)目下使用微信分享功能

    這篇文章主要介紹了vue-cli構(gòu)建項(xiàng)目下使用微信分享功能,本文通過實(shí)例代碼相結(jié)合的形式給大家介紹的非常詳細(xì),感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧
    2018-05-05
  • Vue移動端下拉刷新組件的使用教程

    Vue移動端下拉刷新組件的使用教程

    這篇文章主要介紹了Vue移動端下拉刷新組件的使用教程,每一次我在使用vant組件庫里面list組件和下拉刷新連在一起用的時(shí)候都會出現(xiàn)下拉刷新和列表下滑局部滾動的沖突,這就很難受,這篇文章將解決它
    2023-04-04
  • vue中實(shí)現(xiàn)圖片壓縮 file文件的方法

    vue中實(shí)現(xiàn)圖片壓縮 file文件的方法

    這篇文章主要介紹了vue中實(shí)現(xiàn)圖片壓縮 file文件的方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-05-05
  • 詳解vue的數(shù)據(jù)劫持以及操作數(shù)組的坑

    詳解vue的數(shù)據(jù)劫持以及操作數(shù)組的坑

    這篇文章主要介紹了vue的數(shù)據(jù)劫持以及操作數(shù)組的坑,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04

最新評論