Swipe JS滑动插件

Swipe JS 是一个轻量级的移动滑动组件,支持 1:1 的触摸移动,阻力以及防滑性能都不错,可以让移动web应用展现更多的内容,能解决我们对于移动Web对滑动的需求。

官网:http://www.swipejs.com
github:https://github.com/bradbirdsall/Swipe

  要实现Swipe的滑动和手势非常简单,仅需要遵循一个简单的规则。下面是一个例子:

<div id='slider' class='swipe'>
  <div class='swipe-wrap'>
    <div>1</div>
    <div>2</div>
    <div>3</div>
  </div>
</div>

  里面包裹的三个DIV即是滑动的模块了,在滑块结束后面或页面底部添加事件代码:

window.mySwipe = Swipe(document.getElementById('slider'));

  当然添加了事件后我们还需要添加一些基础的样式,以保证滑块能正常工作:

.swipe {
  overflow: hidden;
  visibility: hidden;
  position: relative;
}
.swipe-wrap {
  overflow: hidden;
  position: relative;
}
.swipe-wrap > div {
  float:left;
  width:100%;
  position: relative;
}

  到这里整个滑动效果就制作完成了,赶紧用手机进行测试下吧!

  Swipe2.0还提供了更多的参数设置:

  • startSlide Integer (default:0) - index position Swipe should start at(滑动的索引值,即从*值开始滑动,默认值为0)

  • speed Integer (default:300) - speed of prev and next transitions in milliseconds.(滑动的速度,默认值300毫秒)

  • auto Integer - begin with auto slideshow (time in milliseconds between slides)(自动滑动,单位为毫秒)

  • continuous Boolean (default:true) - create an infinite feel with no endpoints(是否循环滑动,默认值为true)

  • disableScroll Boolean (default:false) - stop any touches on this container from scrolling the page(停止任何触及此容器上滚动页面,默认值flase)

  • stopPropagation Boolean (default:false) - stop event propagation(停止事件传播,默认值flase)

  • callback Function - runs at slide change.(回调函数)

  • transitionEnd Function - runs at the end slide transition.(滑动过渡时调用的函数)

举个带参数设置的栗子:
<script type="text/javascript">
window.mySwipe = new Swipe(document.getElementById('slider'), {
startSlide: 2,
speed: 400,
auto: 3000,
continuous: true,
disableScroll: false,
stopPropagation: false,
callback: function(index, elem) {},
transitionEnd: function(index, elem) {}
});           
</script>

  Swipe2.0提供的API

prev() slide to prev(上一页)

next() slide to next(下一页)

getPos() returns current slide index position(获取当前索引位置)

getNumSlides() returns the total amount of slides(获取所有滑块总数)

slide(index, duration) slide to set index position (duration: speed of transition in milliseconds)(指数,持续时间)滑动设置索引位置(持续时间:转型速度以毫秒为单位)

  与1.0相比较,2.0做出了很多改进,有更多的API设定,相比各种WebApp开发框架,Swipe也有自己的优缺点,

  优点:

滑动与防滑性能非常不错,用户体验较好
Html结构简单,自定义较灵活

  缺点:

切换后盒子的高度取决于切换内容最大高度,如果某个盒子无内容,那么会出现一个空白区域
当前选中状态在滑动结束后才激活
混合开发时js代码较为繁琐

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Vue.js 2中实现音乐播放器的滑动切换歌曲功能,通常会结合使用`v-on`指令(事件监听)和`v-bind`指令(绑定数据),以及一些常见的JavaScript库如`vue-swipeable-pages`或自定义滚动组件。以下是一个简单的示例: 1. 首先,安装所需的件: ```bash npm install vue-swipeable-pages ``` 2. 在组件中引入并配置swipeable: ```html <template> <div class="swiper-container"> <div v-for="song in songs" :key="song.id" class="swiper-slide"> <img :src="song.cover" /> <h3>{{ song.title }}</h3> <!-- 添加歌曲控制按钮 --> </div> </div> </template> <script> import { SwipeablePages } from 'vue-swipeable-pages'; export default { components: { SwipeablePages, }, data() { return { songs: [ // 假设你有一组歌曲数组 { id: 1, title: 'Song 1', cover: 'cover1.jpg' }, { id: 2, title: 'Song 2', cover: 'cover2.jpg' }, // ... ], }; }, mounted() { this.swipeable = new SwipeablePages(this.$refs.container); }, methods: { nextSong() { // 你可以在这里添加跳转到下一首歌的方法 }, }, destroyed() { this.swipeable.destroy(); }, }; </script> ``` 3. 实现滑动切换和控制按钮: - 在每个歌曲卡片上添加一个`v-on:click`事件监听器,跳转到下一首歌。 - 可能还需要添加左右滑动事件,例如`@swipe-right`或`@swipe-left`,触发`nextSong`方法。 ```html <!-- 每个歌曲卡片 --> <div class="swiper-slide" @click="nextSong"> <!-- ... --> </div> ``` 相关问题-- 1. 如何在Vue中绑定事件监听滑动动作? 2. 如何在Vue中使用件实现滑动切换功能? 3. 在销毁组件时如何正确关闭SwipeablePages实例?

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值