VUE DOM加载后执行自定义事件的方法
2018-09-07 08:47
991 查看
最近想用vue做一个小东西,谁知道一开始就遇到了一个棘手的问题:
首先我想在页面加载前通过ajax请求页面展示所需要的信息,于是我在created钩子函数里面请求了我想要的数据
created:function(){ var url="/indexitem"; var _self=this; $.get(url,function(data){ _self.items=data; }); $.get('/banner',function(data){ _self.banners=data; }); }
这一步很顺利,接下来就是要将数据绑定到对应的元素中,我在这里需要将请求得到的图片地址绑定到轮播图对应的元素中,
我这里采用的是mui框架中提供的图片轮播(移动端,支持手势滑动),问题恰恰就这里:
<div id="slider" class="mui-slider" @click="greet()"> <div class="mui-slider-group mui-slider-loop"> <div class="mui-slider-item mui-slider-item-duplicate"><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" :style="{backgroundImage: 'url(' + banners[banners.length-1].src+ ')',backgroundSize:'cover'}"></a></div> <div class="mui-slider-item" v-for="cc in banners"><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" :style="{backgroundImage: 'url(' + cc.src+ ')',backgroundSize:'cover'}"></a></div> <div class="mui-slider-item mui-slider-item-duplicate"><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" :style="{backgroundImage:'url('+banners[0].src+')',backgroundSize:'cover'}"></a></div> </div> <div class="mui-slider-indicator"> <div class="mui-indicator mui-active"></div> <div class="mui-indicator"></div> <div class="mui-indicator"></div> <div class="mui-indicator"></div> </div> </div>
我绑定完数据之后,发现轮播图失效了,因为我之前用原生js写的时候遇到过同样的问题,我当时的解决办法是等页面加载完成后重新进行滑动初始化,但是今天用vue我蒙了,试了很多生命周期函数也无法确保在页面加载完成后进行初始化。
vue.js更多的希望是通过数据绑定来代替直接通过dom操作,而vue并没有提供渲染完成的钩子。
所以我今天的解决办法是:setTimeout()
在实例化VUE对象后添加下面代码:
setTimeout(function(){ console.log($('#slider').length); var gallery = mui('.mui-slider'); gallery.slider({ interval: 3000//自动轮播周期,若为0则不自动播放,默认为0; }); },1000);
以上这篇VUE DOM加载后执行自定义事件的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- javascript之自定义js封装库兼容主流浏览器实现DOM加载之后,页面完全加载之前执行js
- JQuery中DOM加载与事件执行实例分析
- ListView使用自定义适配器的情况下实现适配器的控件点击事件执行Activity界面中的方法
- JQuery事件执行与DOM加载
- 原生JS实现AJAX、JSONP及DOM加载完成事件,并提供对应方法
- jQuery实现在HTML文档加载完毕后自动执行某个事件的方法
- Vue.js自定义事件的表单输入组件方法
- vue.js--基础事件定义,获取数据,执行方法传值
- 怎样提取jQuery.ready(),DOM加载完毕执行onDOMReady()方法
- 原生JS实现AJAX、JSONP及DOM加载完成事件,并提供对应方法
- ListView使用自定义适配器的情况下实现适配器的文本和图标控件点击事件执行Activity界面中的方法
- jQuery中事件加载 DOM—@ready中调用其他方法,会提示缺少对象的错误
- vue 模板加载之后 执行js 渲染 DOM
- vue加载自定义的js文件方法
- jQuery中事件加载 DOM—@ready中调用其他方法,会提示缺少对象的错误
- JQuery中DOM加载与事件执行实例分析
- JavaScript实现父子dom同时绑定两个点击事件,一个用捕获,一个用冒泡时执行顺序的方法
- JQuery DOM加载与事件执行
- 切换出页面执行事件、切换到页面执行事件 、页面重新加载时执行事件
- Jquery双击事件不触发执行单击事件解决方法