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


Posted in Javascript onApril 01, 2019

首先我们会想着在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'
  }
}
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'
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 关于页面加载完成后执行一个方法的问题详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
js面向对象设计用{}好还是function(){}好(构造函数)
Oct 23 Javascript
js将控件隐藏的方法及display属性介绍
Jul 04 Javascript
Extjs改变树节点的勾选状态点击按钮将复选框去掉
Nov 14 Javascript
使用jQuery将多条数据插入模态框的实现代码
Oct 08 Javascript
js实现照片墙功能实例
Feb 05 Javascript
JS实现alert中显示换行的方法
Dec 17 Javascript
深入浅析JavaScript系列(13):This? Yes,this!
Jan 05 Javascript
JS实现获取剪贴板内容的方法
Jun 21 Javascript
Javascript中JSON数据分组优化实践及JS操作JSON总结
Dec 22 Javascript
vue中如何实现pdf文件预览的方法
Jul 12 Javascript
浅谈vue 多个变量同时赋相同值互相影响
Aug 05 Javascript
详解Vue的列表渲染
Nov 20 Vue.js
VUE脚手架的下载和配置步骤详解
Apr 01 #Javascript
详解JavaScript中的函数、对象
Apr 01 #Javascript
Vue递归组件+Vuex开发树形组件Tree--递归组件的简单实现
Apr 01 #Javascript
基于vue框架手写一个notify插件实现通知功能的方法
Mar 31 #Javascript
基于elementUI实现图片预览组件的示例代码
Mar 31 #Javascript
微信小程序访问豆瓣电影api的实现方法
Mar 31 #Javascript
vue项目首屏打开速度慢的解决方法
Mar 31 #Javascript
You might like
外媒评选出10支2020年最受欢迎的Dota2战队
2021/03/05 DOTA
Zend studio for eclipse中使php可以调用mysql相关函数的设置方法
2008/10/13 PHP
基于PHP Web开发MVC框架的Smarty使用说明
2013/04/19 PHP
php文件上传后端处理小技巧
2016/05/22 PHP
php利用云片网实现短信验证码功能的示例代码
2017/11/18 PHP
关于 Laravel Redis 多个进程同时取队列问题详解
2017/12/25 PHP
Jquery中删除元素的实现代码
2011/12/29 Javascript
JSONP 跨域访问代理API-yahooapis实现代码
2012/12/02 Javascript
JavaScript 对任意元素,自定义右键菜单的实现方法
2013/05/08 Javascript
jQuery简单实现隐藏以及显示特效
2015/02/26 Javascript
jQuery动态星级评分效果实现方法
2015/08/06 Javascript
JavaScript中三种异步上传文件方式
2016/03/06 Javascript
JS动画定时器知识总结
2018/03/23 Javascript
vue异步加载高德地图的实现
2018/06/19 Javascript
JS实现模糊查询带下拉匹配效果
2018/06/21 Javascript
JQuery事件委托原理与用法实例分析
2019/05/13 jQuery
微信小程序登录态和检验注册过没的app.js写法
2019/05/22 Javascript
Vue.js中的extend绑定节点并显示的方法
2019/06/20 Javascript
echarts饼图各个板块之间的空隙如何实现
2020/12/01 Javascript
python基于Tkinter库实现简单文本编辑器实例
2015/05/05 Python
Python实现批量修改文件名实例
2015/07/08 Python
在Django的上下文中设置变量的方法
2015/07/20 Python
浅谈python在提示符下使用open打开文件失败的原因及解决方法
2018/11/30 Python
python dict 相同key 合并value的实例
2019/01/21 Python
python实现文本进度条 程序进度条 加载进度条 单行刷新功能
2019/07/03 Python
详解PyTorch中Tensor的高阶操作
2019/08/18 Python
django 读取图片到页面实例
2020/03/27 Python
html5 input属性使用示例
2013/06/28 HTML / CSS
Madewell美德威尔美国官网:美国休闲服饰品牌
2016/11/25 全球购物
英国版MAC彩妆品牌:Illamasqua
2018/04/18 全球购物
护士自我介绍信
2014/01/13 职场文书
2014年司机工作总结
2014/11/21 职场文书
2014年平安夜寄语
2014/12/08 职场文书
2016年优秀党员教师先进事迹材料
2016/02/29 职场文书
2019年图书室自查报告范本
2019/10/12 职场文书
Python中的tkinter库简单案例详解
2022/01/22 Python