浅谈Vue.js 关于页面加载完成后执行一个方法的问
网络编程 2021-07-04 15:50www.168986.cn编程入门
这篇文章主要介绍了Vue.js 关于页面加载完成后执行一个方法的问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们狼蚁网站SEO优化随着长沙网络推广来一起学习学习吧
我们会想着在mounted或者created里面加入想要执行的方法,有的时候会遇到在你执行这个方法的时候,页面还并没有被渲染完成,所以就会出现这个方法在匹配页面标签报错的情况。
解决思路
1.通过子页面调用父页面的方法,因为在子页面开始渲染的时候,你的父页面肯定是已经渲染好了的,前提这里的方法中是去找寻父页面的标签。
2.直接在本页面监视一个参数,发现参数被初始化了,说明页面也已经加载完成,因为你的页面用到了这个参数。
方法1案例tab页里的子页面如果没有内容就隐藏
父页面代码
<el-tabs v-model="initTab" type="card"> <el-tab-pane label="1信息" name="tab1"> 1 </el-tab-pane> <el-tab-pane label="2报告" name="tab2"> 2 </el-tab-pane> <el-tab-pane label="3信息" name="tab3"> 3 </el-tab-pane> <el-tab-pane label="4信息" name="tab4"> <ziyemian-group @tabShow="tabShow" title="4信息" v-if="detailInfo"> </ziyemian-group> </el-tab-pane> <el-tab-pane label="5信息" name="tab5"> 5 </el-tab-pane> <el-tab-pane label="其它信息" name="tab6"> 6 </el-tab-pane> </el-tabs> import ZiyemianGroup from './ZiyemianGroup.vue' ponents: { 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页隐藏
<el-tabs v-model="initTab" type="card"> <el-tab-pane label="1信息" name="tab1"> 1 </el-tab-pane> <el-tab-pane label="2报告" name="tab2"> 2 </el-tab-pane> <el-tab-pane label="3信息" name="tab3"> 3 </el-tab-pane> <el-tab-pane label="4信息" name="tab4"> <ziyemian-group title="4信息" v-if="detailInfo"> </ziyemian-group> </el-tab-pane> <el-tab-pane label="5信息" name="tab5"> 5 </el-tab-pane> <el-tab-pane label="其它信息" name="tab6"> 6 </el-tab-pane> </el-tabs> import ZiyemianGroup from './ZiyemianGroup.vue' ponents: { 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 关于页面加载完成后执行一个方法的问题详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,长沙网络推广会及时回复大家的。在此也非常感谢大家对狼蚁SEO网站的支持!
编程语言
- 甘肃哪有关键词排名优化购买方式有哪些
- 甘肃SEO如何做网站优化
- 河南seo关键词优化怎么做电话营销
- 北京SEO优化如何做QQ群营销
- 来宾百度关键词排名:提升您网站曝光率的关键
- 卢龙关键词优化:提升您网站排名的策略与技巧
- 山东网站优化的注意事项有哪些
- 四川整站优化怎样提升在搜索引擎中的排名
- 疏附整站优化:提升网站性能与用户体验的全新
- 海南seo主要做什么工作售后服务要做到哪些
- 荣昌百度网站优化:提升您网站的搜索引擎排名
- 河北seo网站排名关键词优化如何做SEO
- 江西优化关键词排名推广售后保障一般有哪些
- 古浪SEO优化:提升你的网站可见性
- 西藏网站排名优化怎么把网站排名在百度首页
- 如何提升阳东百度快照排名:详尽指南