<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
在基於vue框架的前端專案開發過程中,只要涉及到稍微複雜一點的業務,我們都會用到computed計算屬性這個勾點函數,可以用於一些狀態的結合處理和快取的操作。
在computed中,宣告一個函數,並需要提供一個返回值,用於在頁面展示或者結合其他方法進行處理
結合state狀態使用
通過changeName返回一段依賴於name的字串
<li>computed基本使用</li> <li>name值:{{ name }}</li> <li>{{ changeName }}</li> data() { return { name: "zhangsan", }; }, computed: { changeName: function () { return `一段依賴於name:${this.name}的文字`; }, },
主動觸發computed方法,對比不依賴於其他狀態下的區別,通過點選事件,主動觸發一些操作
<li>{{ isCache }}</li> <li>{{ cacheTip }}</li> <li>{{ changeCache }}</li> <li><button @click="handleChange">修改文字</button></li> data() { return { cacheTip: "cacheTip原始值", }; }, computed: { isCache: function () { return `不依賴於任何屬性值的一段文字`; }, changeCache: function () { return `依賴於cacheTip,${this.cacheTip}`; }, }, methods: { handleChange() { this.cacheTip = "cacheTip狀態被修改"; }, },
當我們點選修改狀態時,可以看到,cacheTip被修改只會,依賴於cacheTip的changeCache也會發生改變
isCache因為不和其他狀態關聯,所以還是保持原來的值不變
上面的cacheTip,或者isCache,在computed的通用方法中,預設都是使用了getter方法去獲取處理過的值
可以寫成:
isCache: { setter:function () { return `不依賴於任何屬性值的一段文字`; } }
通過getter和setter,可以進一步對需要處理的狀態進行處理
<li>{{ firstName }}</li> <li>{{ lastName }}</li> <li>{{ setterGetter }}</li> <li><button @click="handleChangeFirst">修改文字</button></li> data() { return { firstName: "lewyon001", lastName: "布歐001", }; }, computed: { setterGetter: { // getter get: function (newValue) { console.log("newValue", newValue); return this.firstName + " " + this.lastName; }, // setter set: function (newValue) { console.log("newValue", newValue); this.firstName = `${newValue.firstName}`; this.lastName = `${newValue.lastName}`; }, }, } methods: { handleChangeFirst() { this.setterGetter = { firstName: "lewyon", lastName: "布歐" }; }, },
computed方法的基礎,包括進階的操作,以及setter和getter方法如上
使用建議:
作為經常使用的方法:
watch顧名思義,屬於vue2.x版本中,監聽和觀察元件狀態變化的勾點函數,常見的應用場景有監聽路由變化,以及父元件傳遞給子元件的props資料的變化等
在使用watch的時候,需要在data中生命一個狀態,並新增到watch當中進行觀察,當發生變化時,watch可以通過預設引數獲取最新的值的變化
<li>name值:{{ name }}</li> <li>{{ nameTip }}</li> <li>通過非同步操作獲取的age:{{ age }}</li> <li><button @click="getUser">修改名字</button></li> let p1 = new Promise((resolve, reject) => { resolve({ age: "14" }); }); data() { return { name: "zhangsan", nameTip: "name未改變", }; }, watch: { name(newVal, oldVal) { // watch可以監聽一些狀態發生更改的時候,做一些處理,修改狀態,或者非同步操作 this.nameTip = "name狀態改變了"; this.getData(); }, }, methods: { getData() { setTimeout(() => { this.getAge(); }, 1000); }, getUser() { this.name = "lisi"; }, getAge() { p1.then((res) => { console.log(res); this.age = res.age; }); }, },
當點選修改的時候,name的值會被修改為lisi,watch監聽到name的修改之後,可以修改nameTip的文字,進行出發修改別的狀態,
我們也可以通過newVal獲取name的最新的值,或者oldVal的值進行一些對比和操作
使用promise和定時器模擬當狀態變化的時候,請求後臺資料並渲染,這是我們在開發過程中,對watch使用的一個比較典型的例子
immediate:當watch第一次載入或者首次繫結的時候,需要監聽和獲取data中的狀態,那麼就可以使用immediate,設定為true,該屬性值為布林值
deep:watch監聽的值為物件的時候,可以使用該屬性進行監聽物件深層次的屬性變化,
注意事項:
deep預設是false,使用的時候,需要自行新增deep:true ,deep和immediate的值一樣,是布林值
<li>{{ immediateNameTip }}</li> data() { return { immediateName: "immediateName原始值", immediateNameTip: "immediateName改變時的提示文字", }; }, immediateName: { handler(newVal, oldVal) { console.log("immediate表示最初監聽值得時候,也執行這段程式碼"); setTimeout(() => { this.immediateNameTip = "immediateName新增immediate,初次繫結也會執行"; }, 2000); }, immediate: true, deep: true, // 只針對物件的深層次屬性變化 },
當設定了immediate為true的時候,首次進來immediateNameTip在定時器執行之後,就會發生更改。
deep這裡不再舉例子,大家可以自己在實戰中去使用和學習。
使用建議;
watch可以作為監聽路由變化,以及通過非同步的方式去獲取資料,同時在一些開銷比較大的狀態監聽都有較多的應用場景,還有購物車功能的實現等場景。
到此這篇關於vue2.x版基於computed詳解computed和watch的使用的文章就介紹到這了,更多相關vue computed和watch內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45