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 相关文章推荐
javascript下判断一个对象是否具有指定名称的属性的的代码
Jan 11 Javascript
JS中批量给元素绑定事件过程中的相关问题使用闭包解决
Apr 15 Javascript
下拉列表select 由左边框移动到右边示例
Dec 04 Javascript
js查找某元素中的所有图片地址的方法
Jan 16 Javascript
Javascript类型系统之String字符串类型详解
Jun 21 Javascript
JS实现倒计时(天数、时、分、秒)
Nov 16 Javascript
AngularJS基于ui-route实现深层路由的方法【路由嵌套】
Dec 14 Javascript
jQuery实现字符串全部替换的方法【推荐】
Mar 09 Javascript
vue监听滚动事件实现滚动监听
Apr 11 Javascript
webpack学习笔记之代码分割和按需加载的实例详解
Jul 20 Javascript
Angular2 组件交互实例详解
Aug 24 Javascript
jQuery简单实现对数组去重及排序操作实例
Oct 31 jQuery
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制作图型计数器的例子
2006/10/09 PHP
PHP 5.5 创建和验证哈希最简单的方法详解
2013/11/07 PHP
php生成N个不重复的随机数实例
2013/11/12 PHP
php中fsockopen用法实例
2015/01/05 PHP
Yii数据库缓存实例分析
2016/03/29 PHP
PHP基于正则批量替换Img中src内容实现获取缩略图的功能示例
2017/06/07 PHP
PHP多维数组排序array详解
2017/11/21 PHP
js检测客户端不是firefox则提示下载
2007/04/07 Javascript
javascript面向对象的方式实现的弹出层效果代码
2010/01/28 Javascript
Jquery实现鼠标移上弹出提示框、移出消失思路及代码
2013/05/19 Javascript
jquery禁止输入数字以外的字符的示例(纯数字验证码)
2014/04/10 Javascript
javascript中attachEvent用法实例分析
2015/05/14 Javascript
jQuery实现拖拽页面元素并将其保存到cookie的方法
2016/06/12 Javascript
JQuery实现table中tr上移下移的示例(超简单)
2018/01/08 jQuery
vue-cli结合Element-ui基于cropper.js封装vue实现图片裁剪组件功能
2018/03/01 Javascript
vue和webpack安装命令详解
2018/06/15 Javascript
基于vue2.0的活动倒计时组件countdown(附源码下载)
2018/10/09 Javascript
vue + element-ui的分页问题实现
2018/12/17 Javascript
微信小程序与公众号卡券/会员打通的问题
2019/07/25 Javascript
[42:32]Secret vs Optic 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
python实现异步回调机制代码分享
2014/01/10 Python
Python语言实现获取主机名根据端口杀死进程
2016/03/31 Python
Python自动生产表情包
2017/03/17 Python
Django ManyToManyField 跨越中间表查询的方法
2018/12/18 Python
tensor和numpy的互相转换的实现示例
2019/08/02 Python
Python模块future用法原理详解
2020/01/20 Python
通过python调用adb命令对App进行性能测试方式
2020/04/23 Python
无需压缩软件,用python帮你操作压缩包
2020/08/17 Python
英国经典球衣网站:Classic Football Shirts
2017/05/20 全球购物
Nobody Denim官网:购买高级女士牛仔裤
2021/03/15 全球购物
泰国最新活动和优惠:Megatix
2020/05/07 全球购物
大学生个人总结的自我评价
2013/10/05 职场文书
应届生求职信写作技巧
2013/10/24 职场文书
欢迎领导标语
2014/06/27 职场文书
施工安全责任书范本
2014/07/24 职场文书
Canvas跟随鼠标炫彩小球的实现
2021/04/11 Javascript