vue移動(dòng)端輕量級(jí)的輪播組件實(shí)現(xiàn)代碼
一個(gè)簡(jiǎn)單的移動(dòng)端卡片滑動(dòng)輪播組件,適用于Vue2.x
c-swipe 2.0 全新歸來(lái)。重寫了全部的代碼,更靠譜的質(zhì)量,更優(yōu)秀的性能
安裝
npm install c-swipe --save
使用
注冊(cè)組件
// main.js // 引入 c-swipe 主文件 import 'c-swipe/dist/swipe.css'; import { Swipe, SwipeItem } from 'c-swipe'; // 全局注冊(cè)組件 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 標(biāo)簽中直接引用
<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', // 注冊(cè)組件 components: { 'swipe': vueSwipe, 'swipe-item': vueSwipeItem }, // ... // ... });
配置
選項(xiàng) | 類型 | 默認(rèn) | 描述 |
---|---|---|---|
v-model | Number | 0 | 綁定了當(dāng)前顯示卡片的索引,該數(shù)據(jù)為雙向綁定,可通過更改 v-model 的值直接更改當(dāng)前顯示卡片 |
pagination | Boolean | true | 是否需要默認(rèn)樣式的導(dǎo)航器 |
loop | Boolean | true | 循環(huán)切換 |
autoplayTime | Number | 0 | 單位 ms,自動(dòng)切換卡片的時(shí)間間隔,值為 0 時(shí)不自動(dòng)切換 |
speed | Number | 300 | 單位 ms, 切換卡片時(shí)的過渡效果的播放時(shí)長(zhǎng) |
minMoveDistance | String | '20%' | 成功觸發(fā)切換卡片事件的最小滑動(dòng)距離,可以傳入百分比,如 '20%',或者傳入具體像素距離,如 '80px'。 |
方法
swipe.reset()
c-swipe 內(nèi)部將重新計(jì)算 Swipe 的寬度,并根據(jù)新的寬度來(lái)計(jì)算滾屏的距離。這個(gè)可以解決容器重置大小后 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>
總結(jié)
以上所述是小編給大家介紹的vue移動(dòng)端輕量級(jí)的輪播組件實(shí)現(xiàn)代碼,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- 解決vue使用vant輪播組件swipe + flex時(shí)文字抖動(dòng)問題
- Vue實(shí)現(xiàn)圖片輪播組件思路及實(shí)例解析
- vue輪播組件實(shí)現(xiàn)$children和$parent 附帶好用的gif錄制工具
- 基于Vue2x實(shí)現(xiàn)響應(yīng)式自適應(yīng)輪播組件插件VueSliderShow功能
- 使用Vue制作圖片輪播組件思路詳解
- 利用Vue實(shí)現(xiàn)移動(dòng)端圖片輪播組件的方法實(shí)例
- 基于vue實(shí)現(xiàn)swipe輪播組件實(shí)例代碼
- 基于vue.js輪播組件vue-awesome-swiper實(shí)現(xiàn)輪播圖
- Vue實(shí)現(xiàn)可復(fù)用輪播組件的方法
相關(guān)文章
詳解基于Vue cli開發(fā)修改外部組件Vant默認(rèn)樣式
這篇文章主要介紹了詳解基于Vue cli開發(fā)修改外部組件Vant默認(rèn)樣式,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04淺談Vue2.4.0 $attrs與inheritAttrs的具體使用
這篇文章主要介紹了淺談Vue2.4.0 $attrs與inheritAttrs的具體使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03vue3 + vite + ts 中使用less文件全局變量的操作方法
這篇文章主要介紹了vue3 + vite + ts 中使用less文件全局變量的操作方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-03-03