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

在vue.js渲染完界面之后如何再調用函數(shù)

 更新時間:2022年07月02日 09:14:18   作者:ruanhongbiao  
這篇文章主要介紹了在vue.js渲染完界面之后如何再調用函數(shù)的實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

vue.js渲染完界面后調用函數(shù)

在使用vue.js框架的時候,有時候會希望在頁面渲染完成之后,再執(zhí)行函數(shù)方法來處理初始化相關的操作,如果只處理頁面位置、寬或者高時,必須要在頁面完全渲染之后才可以,頁面沒有加載完成之前,獲取到的寬高不準確。

使用過jquery的都知道,有個ready方法可以使用,但vue.js則需要結合watch和nextTick方法來使用。

1.下面開始介紹下

在頁面加載一個數(shù)據列表完成之后,頁面自動滾動定位到中間某個列表元素,需要在列表數(shù)據渲染完成,計算列表高度,再控制定位到指定行。

首先介紹下一開始嘗試沒有生效的方案,這也是大家最容易出現(xiàn)錯誤的地方,vue.js提供的mounted函數(shù),表示掛載到實例上去之后調用該鉤子。

2.運行之后

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

3.此時查詢官方api文檔發(fā)現(xiàn)

有一個nextTick方法,意思是在下次 DOM 更新循環(huán)結束之后執(zhí)行延遲回調。

在修改數(shù)據之后立即使用這個方法,獲取更新后的 DOM。

使用之后發(fā)現(xiàn),還是不能解決我所需要的效果

4.繼續(xù)查詢api文檔發(fā)現(xiàn)

watch方法,用于觀察Vue實例上的數(shù)據變動。

對應一個對象,鍵是觀察表達式,值是對應回調,再次嘗試,運行后發(fā)現(xiàn)還是不行

5.最終把watch和nextTick組合一起

watch:{ ? ?
	showList:function(){ ? ? ? ?
	this.goPrice(0); ? ?
}}

showList對應表格頁面的綁定變量

<tr v-for="(item,index) in showList">

6.運行后發(fā)現(xiàn)

已經達到了預期的效果

最后說明下,有時候我們會想到使用setTimeout的方式來實現(xiàn),使用這種方式需要設置個超時執(zhí)行時間,由于渲染時間無法確定,有快有慢,就會出現(xiàn)不穩(wěn)定的現(xiàn)象。

vue渲染完成事件

vue里面本身帶有兩個回調函數(shù)

  • 一個是`Vue.nextTick(callback)`,當數(shù)據發(fā)生變化,更新后執(zhí)行回調。
  • 另一個是`Vue.$nextTick(callback)`,當dom發(fā)生變化,更新后執(zhí)行的回調。

栗子:

...
<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ù)據已經更新')
? ? ? ? ? ? });
? ? ? ? ? ? this.$nextTick(function(){
? ? ? ? ? ? ? ? alert('v-for渲染已經完成')
? ? ? ? ? ? })
? ? ? ? }
? ? }
})

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • 解決vue內存溢出報錯的問題

    解決vue內存溢出報錯的問題

    這篇文章主要介紹了解決vue內存溢出報錯的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • 基于Vue2x的圖片預覽插件的示例代碼

    基于Vue2x的圖片預覽插件的示例代碼

    本篇文章主要介紹了基于Vue2x的圖片預覽插件的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • Vue中video標簽如何實現(xiàn)不靜音自動播放

    Vue中video標簽如何實現(xiàn)不靜音自動播放

    最近在做大屏展示需要在一開始播放引導視頻,產生自動播放需求,下面這篇文章主要給大家介紹了關于Vue中video標簽如何實現(xiàn)不靜音自動播放的相關資料,需要的朋友可以參考下
    2023-01-01
  • vue中beforeRouteLeave實現(xiàn)頁面回退不刷新的示例代碼

    vue中beforeRouteLeave實現(xiàn)頁面回退不刷新的示例代碼

    這篇文章主要介紹了vue中beforeRouteLeave實現(xiàn)頁面回退不刷新的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-11-11
  • Vue項目啟動報錯解決方法大全

    Vue項目啟動報錯解決方法大全

    這篇文章主要給大家介紹了關于Vue項目啟動報錯解決方法的相關資料,文中通過圖文將解決的過程介紹的非常詳細,對大家學習或者使用vue具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-07-07
  • Vue2.0實現(xiàn)調用攝像頭進行拍照功能 exif.js實現(xiàn)圖片上傳功能

    Vue2.0實現(xiàn)調用攝像頭進行拍照功能 exif.js實現(xiàn)圖片上傳功能

    這篇文章主要為大家詳細介紹了Vue2.0實現(xiàn)調用攝像頭進行拍照功能,以及圖片上傳功能引用exif.js,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-04-04
  • Vue.js 使用AntV X6的示例步驟

    Vue.js 使用AntV X6的示例步驟

    X6 是 AntV 旗下的圖編輯引擎,提供了一系列開箱即用的交互組件和簡單易用的節(jié)點定制能力,方便我們快速搭建流程圖、DAG 圖、ER 圖等圖應用。接下來就看看vue如何使用它
    2021-05-05
  • 簡單聊一聊Vue3組件更新過程

    簡單聊一聊Vue3組件更新過程

    我們不光要學會Vue的組件化實現(xiàn)過程,還要懂得組件數(shù)據發(fā)生變化,更新組件的過程,這篇文章主要給大家介紹了關于Vue3組件更新過程的相關資料,需要的朋友可以參考下
    2022-04-04
  • 淺談vue-router 路由傳參的方法

    淺談vue-router 路由傳參的方法

    這篇文章主要介紹了淺談vue-router 路由傳參的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-12-12
  • vue父子組件傳值以及單向數(shù)據流問題詳解

    vue父子組件傳值以及單向數(shù)據流問題詳解

    大家應該都知道父組件可以向子組件通過屬性形式傳遞參數(shù),傳遞的參數(shù)也可以隨時隨意修改;但子組件不能修改父組件傳遞過來的參數(shù),所以下面這篇文章主要給大家介紹了關于vue父子組件傳值以及單向數(shù)據流問題的相關資料,需要的朋友可以參考下
    2021-09-09

最新評論