浅谈Vue.js关于页⾯加载完成后执⾏⼀个⽅法的问题
⾸先我们会想着在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'
components: {
ZiyemianGroup
},
data () {
return {
detailInfo: {},
initTab:‘tab1'
}
}
panemethods: {
tabShow: (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'
components: {
ZiyemianGroup
},
data () {
return {
detailInfo: {},
initTab:‘tab1'
}
}
watch: {
detailInfo: function () {
this.$nextTick(function () {
this.tabShow()
})
}
},
methods: {
tabShow () {
}
}
nextTick⽅法,意思是在下次 DOM 更新循环结束之后执⾏延迟回调。在修改数据之后⽴即使⽤这个⽅法,获取更新后的DOM。
隐藏tab的⽅法我⽤了原⽣js,因为vue⽣成后的页⾯和写的vue页⾯有所差别,所以我直接⽤了最笨的⽅法进⾏匹配。
以上所述是⼩编给⼤家介绍的Vue.js 关于页⾯加载完成后执⾏⼀个⽅法的问题详解整合,希望对⼤家有所帮助,如果⼤家有任何疑问请给我留⾔,⼩编会及时回复⼤家的。在此也⾮常感谢⼤家对⽹站的⽀持!
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论