vue mounted 调用两次的完美解决办法


Posted in Javascript onOctober 29, 2018

在开发中发现其中一个页面moutned调用了两次,而其他页面正常,表示很懵逼,然后查找原因,终于找到了,其实归根到底是要知道mounted的调用机制问题;

vue mounted 调用两次的完美解决办法

情况:在这个页面中出现了mounted 加载了两次的情况;

方法:排除法

首先把 this.$store.commit() 方法注释掉,发现就好了,只加载一次

初步判断是commit  方法导致的

二  验证判断是否正确,不使用commit 方法,该用直接改变变量状态的方法,发现又加载了两次;

再次判断,不是由于commit引起的

三   猜想commit到底实现了什么逻辑,然后找到了v-if  

v-if会重新渲染页面,而mounted 又是在重新渲染完成之后调用的,所以猜想是v-if导致的

然后换成v-show 发现完美解决问题;

v-show 不会重新加载页面,仅仅是显示隐藏而已; 

vue mounted 调用两次的完美解决办法

从网上找来的生命周期图,各位网友可以了解一下,希望给你带来一些启发;

vue mounted 调用两次的完美解决办法 

PS:下面看下mounted函数调用技巧

为了确保dom成功渲染,利用setTimeout()

mounted() {
 setTimeout(() => {
  this._setSliderWidth()
  this._initDots()
  this._initSlider()

  if (this.autoPlay) {
   this._play()
  }
 }, 20)}

浏览器的刷新通常是17毫秒一次,所以这里用了20毫秒

总结

以上所述是小编给大家介绍的vue mounted 调用两次的完美解决办法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JSON 客户端和服务器端的格式转换
Aug 27 Javascript
js href的用法
May 13 Javascript
jquery的$getjson调用并获取远程的JSON字符串问题
Dec 10 Javascript
JavaScript全排列的六种算法 具体实现
Jun 29 Javascript
javascript设计模式之中介者模式Mediator
Dec 30 Javascript
javascript实现3D切换焦点图
Oct 16 Javascript
jQuery移动端日期(datedropper)和时间(timedropper)选择器附源码下载
Apr 19 Javascript
es6系列教程_ Map详解以及常用api介绍
Sep 25 Javascript
小程序实现短信登录倒计时
Jul 12 Javascript
详解微信小程序图片地扯转base64解决方案
Aug 18 Javascript
解决antd日期选择组件,添加value就无法点击下一年和下一月问题
Oct 29 Javascript
ztree+ajax实现文件树下载功能
May 18 Javascript
Electron中实现大文件上传和断点续传功能
Oct 28 #Javascript
JS 正则表达式验证密码、邮箱格式的实例代码
Oct 28 #Javascript
Js 利用正则表达式和replace函数获取string中所有被匹配到的文本(推荐)
Oct 28 #Javascript
深入浅析javascript函数中with
Oct 28 #Javascript
微信小程序动画(Animation)的实现及执行步骤
Oct 28 #Javascript
又拍云 Node.js 实现文件上传、删除功能
Oct 28 #Javascript
javascript中函数的写法实例代码详解
Oct 28 #Javascript
You might like
学习discuz php 引入文件的方法DISCUZ_ROOT
2009/06/21 PHP
使用VisualStudio开发php的图文设置方法
2010/08/21 PHP
php在页面中调用fckeditor编辑器的方法
2011/06/10 PHP
PHP自定义图片缩放函数实现等比例不失真缩放的方法
2016/08/19 PHP
PHP观察者模式实例分析【对比JS观察者模式】
2019/05/22 PHP
Javascript 函数对象的多重身份
2009/06/28 Javascript
JS检测图片大小的实例
2013/08/21 Javascript
基于Css3和JQuery实现打字机效果
2015/08/11 Javascript
基于Bootstrap的Metronic框架实现条码和二维码的生成及打印处理操作
2016/08/29 Javascript
JavaScript的new date等日期函数在safari中遇到的坑
2016/10/24 Javascript
javascript中BOM基础知识总结
2017/02/14 Javascript
easyui-datagrid特殊字符不能显示的处理方法
2017/04/12 Javascript
Vue实现带进度条的文件拖动上传功能
2018/02/23 Javascript
vux uploader 图片上传组件的安装使用方法
2018/05/15 Javascript
vue实现类似淘宝商品评价页面星级评价及上传多张图片功能
2018/10/29 Javascript
angular多语言配置详解
2019/05/16 Javascript
JS根据json数组多个字段排序及json数组常用操作
2019/06/06 Javascript
LayUi使用switch开关,动态的去控制它是否被启用的方法
2019/09/21 Javascript
Node.js API详解之 os模块用法实例分析
2020/05/06 Javascript
jQuery开发仿QQ版音乐播放器
2020/07/10 jQuery
[54:08]LGD女子刀塔学院 DOTA2炼金术士教学
2014/01/09 DOTA
使用Python进行二进制文件读写的简单方法(推荐)
2016/09/12 Python
python单例设计模式实现解析
2020/01/07 Python
python实现粒子群算法
2020/10/15 Python
CSS3实现可关闭的下拉手风琴菜单效果
2015/08/31 HTML / CSS
美国家居用品和厨具购物网站:DealsDot
2019/10/07 全球购物
Ruby如何创建一个线程
2013/03/10 面试题
监察建议书格式
2014/05/19 职场文书
学校开学标语
2014/10/06 职场文书
四风专项整治工作情况汇报
2014/10/28 职场文书
隐形的翅膀观后感
2015/06/10 职场文书
感恩教育主题班会
2015/08/12 职场文书
Mysql 用户权限管理实现
2021/05/25 MySQL
简单介绍Python的第三方库yaml
2021/06/18 Python
Nginx虚拟主机的搭建的实现步骤
2022/01/18 Servers
Python中Schedule模块使用详解 周期任务神器
2022/04/19 Python