vue移动端轻量级的轮播组件实现代码
程序员文章站
2022-06-23 12:33:05
一个简单的移动端卡片滑动轮播组件,适用于vue2.x
c-swipe 2.0 全新归来。重写了全部的代码,更靠谱的质量,更优秀的性能
english documen...
一个简单的移动端卡片滑动轮播组件,适用于vue2.x
c-swipe 2.0 全新归来。重写了全部的代码,更靠谱的质量,更优秀的性能
安装
npm install c-swipe --save
使用
注册组件
// main.js // 引入 c-swipe 主文件 import 'c-swipe/dist/swipe.css'; import { swipe, swipeitem } from 'c-swipe'; // 全局注册组件 vue.component('swipe', swipe); vue.component('swipe-item', swipeitem);
在 .vue 单文件组件中使用:
<swipe v-model="index" style="text-align: center; line-height: 80px; height: 100px; background: #42b983;" > <swipe-item style="height: 100px; line-height: 100px">item1</swipe-item> <swipe-item style="height: 100px; line-height: 100px">item2</swipe-item> <swipe-item style="height: 100px; line-height: 100px">item3</swipe-item> </swipe> new vue({ data: function () { return { index: 0, // two way }; }, });
或者,你想在 html 标签中直接引用
<link href="../node-modules/c-swipe/dist/swipe.css" rel="external nofollow" rel="stylesheet"></head> <script type="text/javascript" src="../node-modules/c-swipe/dist/swipe.js"></script> var vueswipe = swipe.swipe; var vueswipeitem = swipe.swipeitem; new vue({ el: 'body', // 注册组件 components: { 'swipe': vueswipe, 'swipe-item': vueswipeitem }, // ... // ... });
配置
选项 | 类型 | 默认 | 描述 |
---|---|---|---|
v-model | number | 0 | 绑定了当前显示卡片的索引,该数据为双向绑定,可通过更改 v-model 的值直接更改当前显示卡片 |
pagination | boolean | true | 是否需要默认样式的导航器 |
loop | boolean | true | 循环切换 |
autoplaytime | number | 0 | 单位 ms,自动切换卡片的时间间隔,值为 0 时不自动切换 |
speed | number | 300 | 单位 ms, 切换卡片时的过渡效果的播放时长 |
minmovedistance | string | '20%' | 成功触发切换卡片事件的最小滑动距离,可以传入百分比,如 '20%',或者传入具体像素距离,如 '80px'。 |
方法
swipe.reset()
c-swipe 内部将重新计算 swipe 的宽度,并根据新的宽度来计算滚屏的距离。这个可以解决容器重置大小后 c-swipe 滚屏距离不正确的问题。
例:
<swipe ref="swipe"> <swipe-item>item1</swipe-item> <swipe-item>item2</swipe-item> <swipe-item>item3</swipe-item> </swipe> <script> export default { // ... // ... handleresize() { this.$refs.swipe.reset(); } mounted() { // 避免上下文丢失 this.handleresize = this.handleresize.bind(this); window.addeventlistener('resize', this.handleresize); }, destroyed() { window.removeeventlistener('resize', this.handleresize); } // ... // ... } </script>
总结
以上所述是小编给大家介绍的vue移动端轻量级的轮播组件实现代码,希望对大家有所帮助