在vue.js渲染完界面之后如何再調(diào)用函數(shù)
vue.js渲染完界面后調(diào)用函數(shù)
在使用vue.js框架的時(shí)候,有時(shí)候會(huì)希望在頁面渲染完成之后,再執(zhí)行函數(shù)方法來處理初始化相關(guān)的操作,如果只處理頁面位置、寬或者高時(shí),必須要在頁面完全渲染之后才可以,頁面沒有加載完成之前,獲取到的寬高不準(zhǔn)確。
使用過jquery的都知道,有個(gè)ready方法可以使用,但vue.js則需要結(jié)合watch和nextTick方法來使用。
1.下面開始介紹下
在頁面加載一個(gè)數(shù)據(jù)列表完成之后,頁面自動(dòng)滾動(dòng)定位到中間某個(gè)列表元素,需要在列表數(shù)據(jù)渲染完成,計(jì)算列表高度,再控制定位到指定行。
首先介紹下一開始嘗試沒有生效的方案,這也是大家最容易出現(xiàn)錯(cuò)誤的地方,vue.js提供的mounted函數(shù),表示掛載到實(shí)例上去之后調(diào)用該鉤子。

2.運(yùn)行之后
發(fā)現(xiàn)mounted執(zhí)行的時(shí)候,獲取到的height值不對,打個(gè)斷點(diǎn)也可以發(fā)現(xiàn),此時(shí)頁面沒有渲染完成,列表塊還是一片空白

3.此時(shí)查詢官方api文檔發(fā)現(xiàn)
有一個(gè)nextTick方法,意思是在下次 DOM 更新循環(huán)結(jié)束之后執(zhí)行延遲回調(diào)。
在修改數(shù)據(jù)之后立即使用這個(gè)方法,獲取更新后的 DOM。
使用之后發(fā)現(xiàn),還是不能解決我所需要的效果

4.繼續(xù)查詢api文檔發(fā)現(xiàn)
watch方法,用于觀察Vue實(shí)例上的數(shù)據(jù)變動(dòng)。
對應(yīng)一個(gè)對象,鍵是觀察表達(dá)式,值是對應(yīng)回調(diào),再次嘗試,運(yùn)行后發(fā)現(xiàn)還是不行

5.最終把watch和nextTick組合一起
watch:{ ? ?
showList:function(){ ? ? ? ?
this.goPrice(0); ? ?
}}showList對應(yīng)表格頁面的綁定變量
<tr v-for="(item,index) in showList">

6.運(yùn)行后發(fā)現(xiàn)
已經(jīng)達(dá)到了預(yù)期的效果

最后說明下,有時(shí)候我們會(huì)想到使用setTimeout的方式來實(shí)現(xiàn),使用這種方式需要設(shè)置個(gè)超時(shí)執(zhí)行時(shí)間,由于渲染時(shí)間無法確定,有快有慢,就會(huì)出現(xiàn)不穩(wěn)定的現(xiàn)象。
vue渲染完成事件
vue里面本身帶有兩個(gè)回調(diào)函數(shù)
- 一個(gè)是`Vue.nextTick(callback)`,當(dāng)數(shù)據(jù)發(fā)生變化,更新后執(zhí)行回調(diào)。
- 另一個(gè)是`Vue.$nextTick(callback)`,當(dāng)dom發(fā)生變化,更新后執(zhí)行的回調(diào)。
栗子:
...
<ul id="demo">
? ? <li v-for="item in list">{{item}}</div>
</ul>
...new Vue({
? ? el:'#demo',
? ? data:{
? ? ? ? list=[0,1,2,3,4,5,6,7,8,9,10]
? ? },
? ? methods:{
? ? ? ? push:function(){
? ? ? ? ? ? this.list.push(11);
? ? ? ? ? ? this.nextTick(function(){
? ? ? ? ? ? ? ? alert('數(shù)據(jù)已經(jīng)更新')
? ? ? ? ? ? });
? ? ? ? ? ? this.$nextTick(function(){
? ? ? ? ? ? ? ? alert('v-for渲染已經(jīng)完成')
? ? ? ? ? ? })
? ? ? ? }
? ? }
})以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Vue實(shí)現(xiàn)類似Spring官網(wǎng)圖片滑動(dòng)效果方法
這篇文章主要介紹了Vue實(shí)現(xiàn)類似Spring官網(wǎng)圖片滑動(dòng)效果方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-03-03
用vue-cli開發(fā)vue時(shí)的代理設(shè)置方法
今天小編就為大家分享一篇用vue-cli開發(fā)vue時(shí)的代理設(shè)置方法,具有很好的參考價(jià)值。希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09
如何解決npm i下載依賴的時(shí)候出現(xiàn)某依賴版本沖突
這篇文章主要介紹了如何解決npm i 下載依賴的時(shí)候出現(xiàn)某依賴版本沖突問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
Vue?Electron實(shí)現(xiàn)輸入法自動(dòng)刷字?jǐn)?shù)功能詳解
這篇文章主要介紹了Vue?Electron實(shí)現(xiàn)輸入法自動(dòng)刷字?jǐn)?shù)功能,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)C#有一定的幫助,感興趣的小伙伴可以跟隨小編一起了解一下2022-12-12
詳解用vue.js和laravel實(shí)現(xiàn)微信授權(quán)登陸
本篇文章主要介紹了詳解用vue.js和laravel實(shí)現(xiàn)微信授權(quán)登陸,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-06-06
Vue3使用element-plus實(shí)現(xiàn)彈窗效果
本文主要介紹了Vue3使用element-plus實(shí)現(xiàn)彈窗效果,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07

