浅谈Vue.js 关于页面加载完成后执行一个方法的问题
首先我们会想着在mounted或者created里面加入想要执行的方法,但是有的时候会遇到在你执行这个方法的时候,页面还并没有被渲染完成,所以就会出现这个方法在匹配页面标签报错的情况。
解决思路:
1.通过子页面调用父页面的方法,因为在子页面开始渲染的时候,你的父页面肯定是已经渲染好了的,前提这里的方法中是去找寻父页面的标签。
2.直接在本页面监视一个参数,发现参数被初始化了,说明页面也已经加载完成,因为你的页面用到了这个参数。
方法1案例:tab页里的子页面如果没有内容就隐藏
父页面代码
1 2 3 5 6 importZiyemianGroupfrom'./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 importZiyemianGroupfrom'./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关于页面加载完成后执行一个方法的问题详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。