首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

移动端左右滑动效果js

移动端左右滑动效果在JavaScript中可以通过多种方式实现,主要依赖于触摸事件(touch events)和CSS3的过渡效果。以下是实现这一效果的基础概念、优势、类型、应用场景以及可能遇到的问题和解决方案。

基础概念

  • 触摸事件:包括touchstart, touchmove, touchend等,用于捕捉用户在触摸屏上的操作。
  • CSS3过渡和动画:使用transitiontransform属性来创建平滑的滑动效果。

优势

  • 用户体验:滑动切换提供了一种直观且流畅的用户界面交互方式。
  • 性能:相比传统的页面跳转,滑动效果可以减少加载时间,提升应用的响应速度。
  • 适应性:适合各种移动设备和屏幕尺寸。

类型

  1. 基于JavaScript的滑动:直接操作DOM元素的样式来实现滑动效果。
  2. 基于CSS3的滑动:利用CSS3的过渡和变换特性来实现滑动效果。
  3. 混合实现:结合JavaScript和CSS3的优势,实现更复杂的滑动效果。

应用场景

  • 图片轮播:在新闻、电商网站中常见。
  • 页面导航:在单页应用(SPA)中用于页面间的无缝切换。
  • 菜单展开与收起:在侧边栏菜单或抽屉式导航中应用。

示例代码(基于JavaScript和CSS3)

代码语言:txt
复制
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Swipe Example</title>
<style>
  .slider {
    width: 100%;
    overflow: hidden;
    position: relative;
  }
  .slide {
    width: 100%;
    height: 300px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2em;
    transition: transform 0.3s ease;
  }
  .slide:nth-child(1) { background-color: red; }
  .slide:nth-child(2) { background-color: green; }
  .slide:nth-child(3) { background-color: blue; }
</style>
</head>
<body>
<div class="slider" id="slider">
  <div class="slide">Slide 1</div>
  <div class="slide">Slide 2</div>
  <div class="slide">Slide 3</div>
</div>

<script>
  let startX = 0;
  let currentTranslate = 0;
  let prevTranslate = 0;
  let animationID = 0;
  let currentIndex = 0;

  const slider = document.getElementById('slider');
  const slides = document.querySelectorAll('.slide');

  slider.addEventListener('touchstart', touchStart);
  slider.addEventListener('touchmove', touchMove);
  slider.addEventListener('touchend', touchEnd);

  function touchStart(event) {
    startX = event.touches[0].clientX;
    cancelAnimationFrame(animationID);
  }

  function touchMove(event) {
    const currentX = event.touches[0].clientX;
    currentTranslate = prevTranslate + currentX - startX;
  }

  function touchEnd() {
    const movedBy = currentTranslate - prevTranslate;

    if (movedBy < -100 && currentIndex < slides.length - 1) currentIndex += 1;
    if (movedBy > 100 && currentIndex > 0) currentIndex -= 1;

    setSliderPosition();
  }

  function setSliderPosition() {
    currentTranslate = -currentIndex * window.innerWidth;
    prevTranslate = currentTranslate;
    slider.style.transform = `translateX(${currentTranslate}px)`;
    animationID = requestAnimationFrame(setSliderPosition);
  }
</script>
</body>
</html>

可能遇到的问题及解决方案

  1. 滑动不流畅
    • 原因:可能是由于JavaScript执行效率低或者CSS过渡效果设置不当。
    • 解决方案:优化JavaScript代码,减少DOM操作;确保CSS过渡效果设置合理。
  • 触摸事件响应慢
    • 原因:可能是由于页面其他脚本或样式影响了事件处理。
    • 解决方案:检查并优化页面上的其他脚本和样式,确保触摸事件的优先级。
  • 滑动方向错误
    • 原因:可能是由于触摸起始点和结束点的计算有误。
    • 解决方案:仔细检查触摸事件中的坐标计算逻辑,确保滑动方向的准确性。

通过上述方法和代码示例,可以实现一个基本的移动端左右滑动效果,并针对常见问题提供了解决方案。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Axure最快实现移动端左右滑手势滑动效果

昨天项目需要做一个手机版的活动页面的原型,其中需要一个商品展示模块,移动版需要左右滑手势的效果,结果想了小半天才想到怎么非常快速的实现这个小功能。接下来说说我的方法,我觉得应该是最快速的办法了。...建立元件如上图:放一个手机模型,中间看好哪里需要做左右手势效果。在这个模块位置,建立三个小模块,这三个小模块就是需要滑动的部分。2. 转换为动态面板这里是一个小重点,大家注意了。...二、第二步弄好元件以后,要开始加事件了,我们先想想最后需要什么效果:三个小模块可以左右滑动,滑动过程内容要跟着一起动;左右滑需要边界,最左侧不能模块最左侧的位置,最右侧也不能低于模块最右侧的位置。...好了,预览看效果吧。是不是很简单呢?

80520
  • 原生JS实现移动端滑动反弹

    什么是 Touch滑动?就是类似于 PC端的滚动事件,但是在移动端是没有滚动事件的,所以就要用到 Touch事件结合 js去实现,效果如下: ? 1. 准备工作 什么是移动端的 Touch事件?...在移动端 Touch事件可以细分成三种,分别是: touchstart、 touchmove和 touchend,并且 touch事件必须要用 addEventListener去监听。...基本结构 此案例模拟的是移动端的一种滑动菜单效果。...先来张示意图,怎么通过 js 让列表滑动起来 ?...再次滑动 上面的效果图,细心的朋友可能已经发现了问题,在第一次的时候,得到了我们想要的效果,但是在第二次的时候,我们继续向下移动了一段距离,但是 ul并没有接着第一次的位置继续向下,而是瞬间跳了上去。

    10.4K20

    Tips-移动端滑动固顶效果(position: sticky)

    先放个图看看滑动固顶是啥效果: image.png 中间那个 tab 条,平常的时候是固定的,等到页面滑上去的时候,又像 fixed 一样贴在顶部。...position: sticky 就是用来实现这个效果的,元素不脱离文档流,仍然保留高度,所以这个属性真是人畜无害啊,而且效果如丝般润滑,堪比原生。...Android 上实现类似效果 这里我们不得不借助 js 和 positon:fixed。...position: fixed; } 在需要固顶的时候我们将元素的 positon 改为 fixed,但是这里又有个坑,设置元素为 fixed 的时候,相应元素是脱离文档流的,也就是没有高度了,仔细看滑动的时候...为了解决这个跳动,我们可以让原本在下面那个元素加点高度,然后和 sticky 元素重合,为了以后改动页面的时候不影响这个逻辑,用 js 去算高度会比较好。

    2.1K60

    css+js实现左右滑动卡片组件

    最近的一个活动页面需要做一个可以左右滑动的抽签效果,故通过用css的transform属性和js结合来模拟可以无限滚动的效果。...结构与样式 结构:卡片分前后两排,每列插入10个div结点,以便做左右位移效果。 样式:设置每一列都恰好好在中间位置(或中间位置附近),如下所示。 a....目标位移与帧位移 为了做出滑动后到停留位置的缓动效果,所以当用户左右滑动屏幕时,会记录滑动距离,计算出卡片该到的目标位移位置,目标位移位置是有规则的,因为这里有10张卡片均分宽度,位置必须是(100%/...判断第二次滑动是否与第一次不同方向,若不同向需重置上次帧位移为0。以免上次帧位移太大影响移动方向。...使用css transform来做无限滚动的效果,可以避免改变dom结点带来的页面重新布局。 下图是chrome cpu6倍减速调试效果,没有触发layout,FPS基本维持在60左右。

    30.7K102

    基于swiper的手机端上下和左右滑动效果

    2015-04-22 11:26:32 上一篇文章中我向大家介绍了基于swiper的手机端上下和左右滑动效果,但有时候在上下滑动的中间需要有左右滑动的效果,那么我就再来给大家介绍一种基于swiper的手机端上下滑动的同时还能够左右滑动效果...weixin.jpg" style="top: 38%; padding-top:27%;"/> js.../idangerous.swiper-2.1.min.js"> var mySwiper2 = new Swiper...,在第二个sectoion中设置了左右滑动的功能,每一个div为一个页面,可以左右滑动,这里有一个不足之处就是左右箭头,当处于需要左右的第一个页面时左箭头不动,右箭头动。...有兴趣的朋友可以尝试着修改一下达到这个效果。 在来看一下js处代码,这部分代码与上一篇文章的js代码大致相同,还是贴出来让大家看看吧。

    3.3K30

    Android使用ViewPager实现左右循环滑动及轮播效果

    此外,某些区域性的ViewPager(例如展示广告或者公告之类的ViewPager),可能需要自动轮播的效果,即用户在不用滑动的情况下就能够看到其他页面的信息。...循环滑动效果的实现:PagerAdapter 我们知道ViewPager自带的滑动效果非常出色,因此我们基本不需要处理这个滑动,只处理内容的显示。...轮播效果的实现:使用Handler进行更新这里我定义了一个Handler来处理ViewPager的轮播。所谓的“轮播”效果实现起来是这样的:每隔一定时间(这里是3秒)切换一次显示的页面。...通过控制各页面以一定顺序循环播放,就达到了轮播的效果。...为此,我们可以使用Handler的sendEmptyMessageDelayed()方法来实现定时更新,并注意用户也可能会对带有轮播效果的ViewPager手动进行滑动操作,因此我认为用户这时候是希望查看指定页面的

    2.5K20

    移动端效果之ScrollList

    写在前面 列表一直是展示数据的一个重要方式,在手机端的列表展示又和PC端展示不同,毕竟手机端主要靠滑。...下面主要是阅读了饿了么UI组件库mint-ui然后编写出来的效果图: ?...代码请看这里:github 移动端效果之swiper 移动端效果之picker 移动端效果之cellSwiper 移动端效果之IndexList 1 核心解析 1.1 整体思路图 ?...这两点我们在touchmove事件中可以找到相应的代码: // 弹性滑动 // 这里用手指滑动的位移除以比例系数来得出内容应该滑动的位移 // 因此这里的内容滑动的位移一定是会小于手指滑动的位移的,除非你将系列设置为小于...'drop') { // 重置状态为loading,改变位移 Event.trigger('topStatus', 'loading'); // 向下移动

    1.2K60

    移动端效果之CellSwiper

    写在前面 接着之前的移动端效果讲解,刚好项目中需要使用到这一效果,去饿了么的组件库看了一下效果,发现效果和微信端的cellSwiper还是有点差别的,由于项目中又是使用的React,之前使用的React...所有组件都是自己一个字母一个字母码起来的(想来也是辛酸),所以结合之前的swiper,道理类似,实现了类似微信端的抽拉效果。...代码看这里:github 移动端效果之Swiper 移动端效果之Picker 移动端效果之IndexList 移动端效果之scrollList 1....比如这个效果,由于采用的是覆盖式抽拉,因此,需要两个层,上面一个层负责滑动,下面一个层固定,当上面的层滑动完成之后,下面的自然就显示出来了。...// 滑动中 ontouchmove // ... // 这里计算的是上层滑动的距离范围 // 滑动最远不能超过按钮组宽度 // 滑动最小距离就是不滑动,也就是0 offsetLeft = Math.min

    1.2K60

    移动端效果之Picker

    写在前面 接着前面的移动端效果的研究,这次来看看picker选择器的实现原理 移动端效果之Swiper 移动端效果之CellSwiper 移动端效果之IndexList 移动端效果之scrollList...因为毕竟是移动端,滑动不可避免。这次,源码中的对滑动事件进行了封装,兼容了PC端以及排除了拖动和选择造成的影响,具体看一下分析。...` /** * draggable.js * 只是起到一定的兼容性 * 实质和直接调用 el.addEventListener('touchstart', startFn); 并没有多大差别...这点可以参看前面一篇文章移动端效果之Swiper,这篇文章中有着相同的方法。...其实感觉这样挺费事,因为在touchend中最后肯定会计算translate值,我们只需要每次保存最后滑动的移动值就好了,而不要每次都要在DOM中取。

    2K40

    移动端效果之Swiper

    写在前面 最近在做移动端方面运用到了饿了么的vue前端组件库,因为不想单纯用组件而使用它,故想深入了解一下实现原理。后续将会继续研究一下其他的组件实现原理,有兴趣的可以关注下。...移动端效果之Picker 移动端效果之CellSwiper 移动端效果之IndexList 移动端效果之scrollList 代码在这里:戳我 or github 1....// 这里的 translate 方法其实很简单,在滑动的时候去除了动画效果`transition`,单纯改变位移 // 而在滑动结束的时候,加上`transition`,使得滑动到最后释放的过渡更加自然...translate(currentPage, -pageWidth, speed, callback); if (nextPage) { // 下一面移动视野中...有一个细节就是,在滑动中transition的效果置为空,是为了防止在滑动中上一页与下一页因为过渡存在而位移得不自然,在滑动结束后再给他们加上动画效果。

    1.3K80
    领券