vue+swiper实现组件化开发的实例代码


Posted in Javascript onOctober 26, 2017

swiper的组件

<template>
  <div class="swiper-container">
    <div class="swiper-wrapper">
      <div class="swiper-slide" v-for="item in swiper"><img :src="item.room_src" alt=""></div>
      <!--<div class="swiper-slide" v-for="item in test"><img :src="item.room_src" alt=""></div>-->
    </div>
  </div>
</template>
<script>
 import Swiper from 'swiper'
 export default {
  name: 'swiper',
  data() {
   return {
    mySwiper: null,
//    test: [
//     "https://rpic.douyucdn.cn/acrpic/171024/288016_0921.jpg",
//     "https://rpic.douyucdn.cn/acrpic/171024/748396_0924.jpg",
//     "https://rpic.douyucdn.cn/acrpic/171024/453751_0922.jpg",
//     "https://rpic.douyucdn.cn/acrpic/171024/79663_0920.jpg"
//    ]
   }
  },
  props: ['swiper'], //swiper的就是test这个数据传递来的
  methods: {
   _initSwiper() {
    this.mySwiper = new Swiper('.swiper-container', {
     autoplay: 5000,//可选选项,自动滑动
    })
   },
   _updateSwiper() {
    this.$nextTick(() => {
     this.mySwiper.update(true); //swiper update的方法
    })
   },
   swiperUpdate() {
    if (this.mySwiper) { //节点存在
     this._updateSwiper(); //更新
    } else {
     this._initSwiper(); //创建
    }
   },
  },
  watch: {
   //通过props传来的数据 和 组件一加载节点就创建成功 二者不是同步,实时监听的swiper(传递的值)的变化
   swiper() {
    this.swiperUpdate();
   }
  },
  mounted() {
   this.swiperUpdate(); //页面一加载拉去数据创建节点
  }
 }
</script>
<style lang="scss" scoped>
  .swiper-container {
    width: 100%;
    height: 4rem;
    margin-top: 0.9rem;
    .swiper-wrapper {
      width: 100%;
      height: 100%;
      .swiper-slide {
        background-size: cover;
        width: 100%;
        height: 4rem;
        img {
          width: 100%;
          height: 100%;
        }
      }
    }
  }
</style>

home.vue 调用的组件方法

//html
  <swiper :swiper="roomList.slice(6,10)" ></swiper>
//js
 import swiper from 'components/swiper/swiper'
 components: {
   swiper
  },

问题:如果单纯的调用_initSwiper的方法,会发现页面是不能滚动的,但是页面随便修改东西,然后保存的swiper又可以滚动的,这个个原因是初始swiper的节点没有创建成功,值页面有穿进去的,一层一层的可以打印swiper的值为空的,当修改东西值就能传递进去的,所以的这里的我们需要通过判断节点是否成功来update siwper的方法

Javascript 相关文章推荐
写了10年的Javascript也未必全了解的连续赋值运算
Mar 25 Javascript
Package.js  现代化的JavaScript项目make工具
May 23 Javascript
setInterval计时器不准的问题解决方法
May 08 Javascript
form.submit()不能提交表单的原因分析
Oct 23 Javascript
IE6/IE7中JavaScript json提示缺少标识符、字符串或数字问题处理
Dec 16 Javascript
EasyUI中combobox默认值注意事项
Mar 01 Javascript
实现非常简单的js双向数据绑定
Nov 06 Javascript
JS实现的手机端精简幻灯片效果
Sep 05 Javascript
vue.js学习笔记之绑定style样式和class列表
Oct 31 Javascript
JS+WCF实现进度条实时监测数据加载量的方法详解
Dec 19 Javascript
JavaScript控制浏览器全屏显示简单示例
Jul 05 Javascript
Vue运用transition实现过渡动画
May 06 Javascript
canvas+gif.js打造自己的数字雨头像的示例代码
Oct 26 #Javascript
使用Bootrap和Vue实现仿百度搜索功能
Oct 26 #Javascript
Vue利用路由钩子token过期后跳转到登录页的实例
Oct 26 #Javascript
vue路由跳转时判断用户是否登录功能的实现
Oct 26 #Javascript
webpack3之loader全解析
Oct 26 #Javascript
JS使用正则表达式找出最长连续子串长度
Oct 26 #Javascript
AngularJS实现的输入框字数限制提醒功能示例
Oct 26 #Javascript
You might like
php ignore_user_abort与register_shutdown_function 使用方法
2009/06/14 PHP
使用php统计字符串中中英文字符的个数
2013/06/23 PHP
php实现汉字验证码和算式验证码的方法
2015/03/07 PHP
php结合md5实现的加密解密方法
2016/01/25 PHP
PHP实现上传多文件示例代码
2017/02/20 PHP
PHP中PDO事务处理操作示例
2018/05/02 PHP
Laravel框架生命周期与原理分析
2018/06/12 PHP
Laravel中的chunk组块结果集处理与注意问题
2018/08/15 PHP
YII框架实现自定义第三方扩展操作示例
2019/04/26 PHP
javascript判断机器是否联网的2种方法
2013/08/09 Javascript
js判断设备是否为PC并调整图片大小
2014/02/12 Javascript
iframe里的页面禁止右键事件的方法
2014/06/10 Javascript
js改变style样式和css样式的简单实例
2016/06/28 Javascript
JQuery之proxy实现绑定代理方法
2016/08/01 Javascript
JS实现点击表头表格自动排序(含数字、字符串、日期)
2017/01/22 Javascript
canvas绘制表盘时钟
2017/01/23 Javascript
js中获取键盘按下键值event.keyCode、event.charCode和event.which的兼容性详解
2017/03/15 Javascript
Angular6 发送手机验证码按钮倒计时效果实现方法
2019/01/08 Javascript
vue插槽slot的简单理解与用法实例分析
2020/03/14 Javascript
[01:06:25]Secret vs Liquid 2018国际邀请赛淘汰赛BO3 第一场 8.25
2018/08/29 DOTA
使用Python脚本将Bing的每日图片作为桌面的教程
2015/05/04 Python
Python中static相关知识小结
2018/01/02 Python
python中PS 图像调整算法原理之亮度调整
2019/06/28 Python
python SQLAlchemy的Mapping与Declarative详解
2019/07/04 Python
python中 * 的用法详解
2019/07/10 Python
让你相见恨晚的十个Python骚操作
2020/11/18 Python
2014年圣诞节倒计时网页的制作过程
2014/12/05 HTML / CSS
迷你分体式空调:SoGoodToBuy
2018/08/07 全球购物
EJB的角色和三个对象
2015/12/31 面试题
JPA的特点
2014/10/25 面试题
幼儿园教师奖惩制度
2014/02/01 职场文书
激情洋溢的毕业生就业求职信
2014/03/15 职场文书
初中开学典礼新闻稿
2015/07/17 职场文书
关于环保的宣传稿
2015/07/23 职场文书
2016年七夕爱情寄语
2015/12/04 职场文书
使用logback实现按自己的需求打印日志到自定义的文件里
2021/08/30 Java/Android