浅谈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快速排序的实现代码
Dec 08 Javascript
js整数字符串转换为金额类型数据(示例代码)
Dec 26 Javascript
Javascript 动态改变imput type属性
Nov 01 Javascript
纯JS实现表单验证实例
Dec 24 Javascript
详解vue-router2.0动态路由获取参数
Jun 14 Javascript
JS+HTML5实现图片在线预览功能
Jul 22 Javascript
jQuery实现点击下拉框中的值累加到文本框中的方法示例
Oct 28 jQuery
vue项目开发中setTimeout等定时器的管理问题
Sep 13 Javascript
利用Vue构造器创建Form组件的通用解决方法
Dec 03 Javascript
spring+angular实现导出excel的实现代码
Feb 27 Javascript
JS实现随机抽选获奖者
Nov 07 Javascript
原生JS实现拖拽功能
Dec 16 Javascript
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
PHP中替换键名的简易方法示例详解
2014/01/07 PHP
PHP中文竖排转换实现方法
2015/10/23 PHP
js实现浏览器的各种菜单命令比如打印、查看源文件等等
2013/10/24 Javascript
JS取文本框中最小值的简单实例
2013/11/29 Javascript
javascript中普通函数的使用介绍
2013/12/19 Javascript
javascript数据结构与算法之检索算法
2015/04/04 Javascript
JQuery显示、隐藏div的几种方法简明总结
2015/04/16 Javascript
JavaScript数据类型学习笔记
2016/01/25 Javascript
jQuery实现每隔几条元素增加1条线的方法
2016/06/27 Javascript
微信小程序 MINA文件结构
2016/10/17 Javascript
使用Ajax与服务器(JSON)通信实例
2016/11/04 Javascript
AngularJS基于ngInfiniteScroll实现下拉滚动加载的方法
2016/12/14 Javascript
原生js获取浏览器窗口及元素宽高常用方法集合
2017/01/18 Javascript
微信小程序小组件 基于Canvas实现直播点赞气泡效果
2020/05/29 Javascript
vue实现导航栏效果(选中状态刷新不消失)
2017/12/13 Javascript
ES6/JavaScript使用技巧分享
2017/12/14 Javascript
详解如何解决Vue和vue-template-compiler版本之间的问题
2018/09/17 Javascript
Mint UI组件库CheckList使用及踩坑总结
2018/12/20 Javascript
vue实现简单的日历效果
2020/09/24 Javascript
angular8.5集成TinyMce5的使用和详细配置(推荐)
2020/11/16 Javascript
Python的ORM框架SQLAlchemy入门教程
2014/04/28 Python
Python脚本暴力破解栅栏密码
2015/10/19 Python
浅谈五大Python Web框架
2017/03/20 Python
使用Python对SQLite数据库操作
2017/04/06 Python
python 切换root 执行命令的方法
2019/01/19 Python
Python实现html转换为pdf报告(生成pdf报告)功能示例
2019/05/04 Python
解决pycharm remote deployment 配置的问题
2019/06/27 Python
浅谈django框架集成swagger以及自定义参数问题
2020/07/07 Python
Python爬虫爬取微信朋友圈
2020/08/06 Python
Python3 用matplotlib绘制sigmoid函数的案例
2020/12/11 Python
关于CSS Tooltips(鼠标经过时显示)的效果
2013/04/10 HTML / CSS
文明礼仪小标兵事迹
2014/01/12 职场文书
社会调查研究计划书
2014/05/01 职场文书
2014党员四风对照检查材料思想汇报
2014/09/17 职场文书
护理专业自荐信范文
2015/03/06 职场文书
SQL试题 使用窗口函数选出连续3天登录的用户
2022/04/24 Oracle