dom加载后执行 vue_浅谈Vue.js 关于页面加载完成后执行一个方法的问题

首先我们会想着在mounted或者created里面加入想要执行的方法,但是有的时候会遇到在你执行这个方法的时候,页面还并没有被渲染完成,所以就会出现这个方法在匹配页面标签报错的情况。

解决思路:

1.通过子页面调用父页面的方法,因为在子页面开始渲染的时候,你的父页面肯定是已经渲染好了的,前提这里的方法中是去找寻父页面的标签。

2.直接在本页面监视一个参数,发现参数被初始化了,说明页面也已经加载完成,因为你的页面用到了这个参数。

方法1案例:tab页里的子页面如果没有内容就隐藏

父页面代码

1

2

3

5

6

import ZiyemianGroup from './ZiyemianGroup.vue'

components: {

ZiyemianGroup

},

data () {

return {

detailInfo: {},

initTab:‘tab1'

}

}

methods: {

tabShow: (data) => {

document.getElementsByClassName('el-tabs__item').item(4).style.display = data

},

}

然后是ZiyemianGroup.vue的代码,这里主要就是方法调用,页面自己搞定

data () {

return {

list: []

}

},

mounted () {

this.init()

},

methods: {

init() {

if (list.length > 0) {

this.$emit('whiteShow', 'inline')

} else {

this.$emit('whiteShow', 'none')

}

)

}

list是子页面的内容,这样如果子页面没有内容就可以隐藏掉了

方法2案例:我这边需要tab页隐藏

1

2

3

5

6

import ZiyemianGroup from './ZiyemianGroup.vue'

components: {

ZiyemianGroup

},

data () {

return {

detailInfo: {},

initTab:‘tab1'

}

}

watch: {

detailInfo: function () {

this.$nextTick(function () {

this.tabShow()

})

}

},

methods: {

tabShow () {

document.getElementsByClassName('el-tabs__item').item(6).style.display = 'none' // 隐藏tab6

}

}

nextTick方法,意思是在下次 DOM 更新循环结束之后执行延迟回调。在修改数据之后立即使用这个方法,获取更新后的 DOM。

隐藏tab的方法我用了原生js,因为vue生成后的页面和写的vue页面有所差别,所以我直接用了最笨的方法进行匹配。

以上所述是小编给大家介绍的Vue.js 关于页面加载完成后执行一个方法的问题详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值