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

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

Vue.js中的計算屬性、監視屬性與生命周期詳解

瀏覽:50日期:2022-09-29 08:39:11
目錄前言計算屬性計算屬性介紹入門案例統計價格案例getter和setter方法計算屬性緩存監視屬性概述代碼總結Vue生命周期初始化階段更新階段死亡階段總結前言

本章節咱們來說一下Vue中兩個非常重要的計算屬性、監視屬性和生命周期,不廢話直接上干貨

計算屬性計算屬性介紹

在模板中可以直接通過插值語法顯示一些data中的數據,有些情況下我們需要對數據進行轉化或者計算后顯示,我們可以使用computed選項來計算,這時有些小伙伴可能就會問,我直接定義函數再調用不就行了,為什么還要整一個計算屬性呢?這個問題在下邊再做解釋,我們先來看一下計算屬性怎么用!

入門案例

需求

將人的姓和名拼接在一起

代碼

<!DOCTYPE html><html><head><meta charset='utf-8'><title></title><script src='https://cdn.jsdelivr.net/npm/vue/dist/vue.js'></script></head><body><div id='app'><!-- 原始拼接方式 --><p>{{fastName}} {{lastName}}</p><!-- 在模板語法中進行計算 --><p>{{fastName + ' ' + lastName}}</p><!-- 調用函數計算 --><p v-text='fullName2()'></p><!-- 使用計算屬性計算 --><p>{{fullName1}}</p></div></body><script type='text/javascript'>var app = new Vue({el: '#app',data: {fastName: 'Tracy',lastName: 'McGrady'},computed: {fullName1: function(){return this.fastName + ' ' + this.lastName}},methods: {fullName2: function(){return this.fastName + ' ' + this.lastName}}})</script></html>

效果

Vue.js中的計算屬性、監視屬性與生命周期詳解

統計價格案例

代碼

<!DOCTYPE html><html><head><meta charset='utf-8'><title></title><script src='https://cdn.jsdelivr.net/npm/vue/dist/vue.js'></script></head><body><div id='app'><p>{{totalPrice}}</p></div></body><script type='text/javascript'>var app = new Vue({el: '#app',data: {bookes: [{id: 100,name: ’Unix編程藝術’,price: 119},{id: 200,name: ’Java編程思想’,price: 105},{id: 300,name: ’高并發編程’,price: 98},{id: 400,name: ’Spring5’,price: 99},]},computed: {totalPrice: function(){let result = 0;// 普通循環/* for(let i = 0;i < this.bookes.length;i++){result += this.bookes[i].price;} */// 增強for循環,i為索引/* for(let i in this.bookes){result += this.bookes[i].price;} */// ES6新增for循環直接獲取對象for(let book of this.bookes){result += book.price}return result;}}})</script></html>getter和setter方法

介紹

計算屬性的完整寫法其實是其中包含了getter和setter方法,聲明一個fullName對象,因為我們一般只獲取值,所以會將其省略寫成上邊案例的方式,我們在獲取數據時會調用get方法,設置數據時會調用set方法

代碼

<!DOCTYPE html><html><head><meta charset='utf-8'><title></title><script src='https://cdn.jsdelivr.net/npm/vue/dist/vue.js'></script></head><body><div id='app'><p>{{fullName}}</p></div></body><script type='text/javascript'>var app = new Vue({el: '#app',data: {firstName: 'Tracy',lastName: 'McGrady'},// 計算屬性computed: {// 計算對象fullName:{// 設置數據set: function(){console.log(’---’);},// 獲取數據get: function(){return this.firstName + ' ' + this.lastName;}}}})</script></html>計算屬性緩存

這里就來回答一下上邊的methods和computed的區別的問題,下方代碼分別使用插值語法、methods、計算屬性來做數據渲染。

代碼

<!DOCTYPE html><html><head><meta charset='utf-8'><title></title><script src='https://cdn.jsdelivr.net/npm/vue/dist/vue.js'></script></head><body><div id='app'><!-- 原始方式,該方式面對數據計算時比較繁瑣,不推薦使用 --><p>名字:{{name}} 工作:{{job}}</p><!-- methods方式,每獲取一次數據就調用一次函數 --><p>{{getInfo1()}}</p><p>{{getInfo1()}}</p><p>{{getInfo1()}}</p><p>{{getInfo1()}}</p><!-- computed方式,當數據沒有發生變化時,僅調用一次,會將數據進行緩存 --><p>{{getInfo2}}</p><p>{{getInfo2}}</p><p>{{getInfo2}}</p><p>{{getInfo2}}</p><p>{{getInfo2}}</p></div></body><script type='text/javascript'>var app = new Vue({el: '#app',data: {name: '麥迪',job: 'NBA球星'},methods: {getInfo1: function(){console.log('methods');return '名字:' + this.name + '工作: ' + this.job;}},computed: {getInfo2: function(){console.log('computed');return '名字:' + this.name + '工作: ' + this.job;}}})</script></html>

圖解

Vue.js中的計算屬性、監視屬性與生命周期詳解

結論

methods和computed看起來都能實現我們的功能 計算屬性會進行緩存,如果多次使用時,計算屬性只會調用一次 監視屬性概述

我們可以使用watch來監聽指定數據的變換,進而調用對應的邏輯處理數據

代碼

<!DOCTYPE html><html><head><meta charset='utf-8'><title></title></head><body><div id='app'><input type='text' v-model='firstName' /><input type='text' v-model='lastName' /><input type='text' v-model='fullName' /></div></body><script src='http://www.b3g6.com/bcjs/js/vue.js' type='text/javascript' charset='utf-8'></script><script type='text/javascript'>const app = new Vue({el: '#app',data: {firstName: 'A',lastName: 'B',fullName: 'AB'},// 監視屬性watch: {firstName(value) {this.fullName = value + this.lastName},lastName(value) {this.fullName = this.firstName + value}}})</script></html>總結

監聽屬性要比計算屬性代碼多很多,計算屬性只需要計算數據即可,而監聽屬性需要監聽每個數據的變化

Vue生命周期

下圖展示了實例的生命周期。你不需要立馬弄明白所有的東西,不過隨著你的不斷學習和使用,它的參考價值會越來越高

Vue.js中的計算屬性、監視屬性與生命周期詳解

生命周期大致分為三個階段 初始化階段 、 更新階段 、 死亡階段

初始化階段

該階段在new Vue 實例時調用,并且只調用一次

beforeCreate:創建之前調用函數

created:創建之后調用函數

之后進行掛載和模板渲染

beforeMount:掛載前操作,去替換el選中的標簽

Mounted:掛載完成,數據顯示在瀏覽器上

更新階段

當數據發生變化時進入該階段,該階段會 頻繁調用

beforeUpdate:當數據發生修改時觸發

updated:虛擬DOM發生修改后,也就是數據修改后調用

死亡階段

死亡階段 也只 調用一次

beforeDestroy:銷毀之前

destroyed:銷毀

示例代碼如下

<!DOCTYPE html><html><head><meta charset='utf-8'><title></title></head><body><div id='app'><p v-show='isShow'>{{message}}</p><p>{{isShow}}</p><button type='button' @click='destroyVM'>取消布靈布靈</button></div></body><script src='http://www.b3g6.com/bcjs/js/vue.js' type='text/javascript' charset='utf-8'></script><script type='text/javascript'>const app = new Vue({el: '#app',data: {message: '若隱若現',isShow: true},beforeCreate() {console.log('beforeCreate');},created() {console.log('create');},beforeMount() {console.log('beforeMount');},mounted() {console.log('mounted');// 創建定時器this.intervald = setInterval(()=>{console.log('-------'+this.isShow);this.isShow = !this.isShow;},1000)},beforeUpdate() {console.log('beforeUpdate');},updated() {console.log('updated');},beforeDestroy() {console.log('beforeDestroy');// 清除定時器clearInterval(this.intervald)},destroyed() {console.log('destroyed');},methods: {// 干掉vmdestroyVM() {// 調用銷毀函數this.$destroy()}}})</script></html>

圖示如下,在頁面刷新時依次調用 beforeCreate、created、beforeMount、mounted,定時器運行修改isShow數據時多次調用 beforeUpdate、updated,點擊按鈕調用注銷函數,調用beforeDestroy、destroyed

總的來說created、mounted、beforeDestroy較為常用

created、mounted:發送ajax請求,啟動定時器等異步任務 beforeDestroy:做收尾工作,如:清除定時器

Vue.js中的計算屬性、監視屬性與生命周期詳解

總結

到此這篇關于Vue.js中計算屬性、監視屬性與生命周期的文章就介紹到這了,更多相關Vue計算屬性、監視屬性與生命周期內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
视频一区二区三区中文字幕| 久久久久国产| 97精品国产福利一区二区三区| 日本中文字幕视频一区| 日韩电影免费在线观看| 久久精品国产99| 久久免费精品| 蜜臀国产一区| 国产精品久久久久77777丨| 日韩av一区二区三区四区| 亚洲精品护士| 亚洲五月婷婷| 美女尤物久久精品| 亚洲18在线| 日韩高清一区| 欧美日韩国产精品一区二区亚洲| 人人爽香蕉精品| 麻豆精品国产91久久久久久| 国产一区二区三区久久| 日韩一级欧洲| 亚洲69av| 欧美不卡视频| 热久久久久久| 国产精品玖玖玖在线资源| 精品三级国产| 国产一卡不卡| 亚洲专区一区| 国产精品99在线观看| 亚洲精品黄色| 久久要要av| 久久国产三级| 三级欧美韩日大片在线看| 色乱码一区二区三区网站| 国产调教精品| 美女国产精品| 激情婷婷久久| 久久久精品国产**网站| 天堂成人免费av电影一区| 国产欧美日韩在线一区二区 | 噜噜噜久久亚洲精品国产品小说| 国产麻豆一区二区三区精品视频| 午夜精品久久久久久久久久蜜桃| 国产欧美一级| 亚洲欧美久久久| 亚洲黄色免费看| 日本a级不卡| 亚洲中午字幕| 国产视频一区在线观看一区免费| 欧美激情日韩| 午夜视频一区二区在线观看| 成人免费电影网址| 国产麻豆精品久久| 视频精品一区二区| 亚洲精品一区二区妖精| 999久久久国产精品| 国产成人调教视频在线观看| 日本亚洲欧美天堂免费| 日本中文字幕不卡| 老牛影视一区二区三区| 日韩综合一区二区| 最新亚洲国产| 国产精品视区| 婷婷色综合网| 亚洲一区欧美激情| 一区二区三区午夜视频| 日韩成人精品一区二区三区 | 日韩一区二区久久| 日韩理论视频| 国产韩日影视精品| 99国产成+人+综合+亚洲欧美| av高清不卡| 精品视频高潮| 欧美美女一区| 日韩一区二区三区精品| 日韩成人精品一区二区| 色偷偷色偷偷色偷偷在线视频| 国产成人免费精品| 亚洲精品小说| 国产精品久久久久77777丨 | 欧美激情久久久久久久久久久| 97成人在线| 国产精品videossex久久发布| 国产精品日韩精品中文字幕| 国产精品日韩精品中文字幕| 日韩久久视频| 伊人久久亚洲影院| 欧美国产中文高清| 亚洲激情精品| 日本成人手机在线| 国产精品一区2区3区| 美女av在线免费看| 亚洲国产影院| 久久不见久久见免费视频7| 麻豆视频观看网址久久| 蜜桃成人av| 欧美一区自拍| 人人爽香蕉精品| 国内精品麻豆美女在线播放视频| 国产综合婷婷| 国产精品久久| 成人久久一区| 久久精品国产99国产| 麻豆久久精品| 久久精品国产亚洲夜色av网站| 国产亚洲精品v| 国产不卡人人| 91精品啪在线观看国产爱臀| 激情五月综合网| 久久av偷拍| 国模 一区 二区 三区| 亚洲专区视频| 亚洲欧美日韩高清在线| 美女久久久精品| 欧美 日韩 国产一区二区在线视频 | 欧美日韩视频| 中文字幕高清在线播放| 国产模特精品视频久久久久| 日本精品黄色| 免费视频一区二区三区在线观看| 三级一区在线视频先锋| 久久精品123| 免费视频亚洲| 久久久久国产| 99riav1国产精品视频| 尹人成人综合网| 1024精品久久久久久久久| 福利一区视频| 国产aⅴ精品一区二区四区| 精品99在线| 国产精品高潮呻吟久久久久| 欧美伊人影院| 亚洲精品欧美| 国产一精品一av一免费爽爽| 欧美在线看片| 乱一区二区av| 久久精品五月| 美女av在线免费看| 999久久久精品国产| 欧美1区2区3区| 视频在线观看91| 日韩视频一二区| 国产亚洲精品精品国产亚洲综合| 欧美一级全黄| 欧美日韩精品一区二区三区在线观看| 伊人国产精品| 亚洲欧美专区| 日韩久久99| 欧美国产小视频| 中文精品视频| 国产精品一区二区三区www| 日产精品一区二区| 啪啪国产精品| 亚洲精品大片| 精品一区二区三区视频在线播放| 久久99影视| 久久精品一区二区不卡| 免费不卡在线视频| 欧美日韩精品一区二区三区视频| 国产精品一线天粉嫩av| 精品一区91| 精品一区三区| 中文一区一区三区免费在线观| 麻豆视频久久| 麻豆亚洲精品| sm久久捆绑调教精品一区| 奶水喷射视频一区| 超碰在线99| 日本a级不卡| 精品欧美激情在线观看| 国产乱码精品一区二区三区亚洲人| 久久久久一区| 国产精品中文字幕制服诱惑| 美女少妇全过程你懂的久久| 97se亚洲| 日韩在线卡一卡二| 日韩在线观看不卡| 亚洲欧美日韩一区在线观看| 国产精品尤物| 亚洲欧美日本国产专区一区| 美女国产精品久久久| 国产高清一区二区| 四虎4545www国产精品 | 激情欧美丁香| 国产一区二区三区四区大秀| 国产亚洲一区二区手机在线观看 | 久久久久久免费视频| 清纯唯美亚洲综合一区| 爽好多水快深点欧美视频| 亚洲天堂成人| 精品一区二区三区的国产在线观看 | 久久伊人亚洲| 国产精品婷婷| 欧美精品一区二区久久| 日韩精品麻豆| 免费在线亚洲欧美| 日本亚洲不卡| 日韩欧美美女在线观看| 香蕉视频成人在线观看| 亚洲免费福利| 999精品色在线播放|