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

js触屏滑动banner

基础概念: 触屏滑动banner是指在移动设备上,通过触摸屏幕来滑动切换banner图的一种交互方式。它通常依赖于JavaScript库或框架来实现平滑的滑动效果和触摸事件的处理。

优势

  1. 用户体验好:触屏滑动使得用户可以直接通过手指操作,无需点击,更加直观便捷。
  2. 适应性强:自动适应不同屏幕尺寸和设备类型。
  3. 交互性强:可以添加各种动画效果,提升视觉吸引力。

类型

  • 无限循环滑动:banner图可以无限循环播放。
  • 自动播放与暂停:在一定时间后自动切换图片,并在用户触摸时暂停自动播放。
  • 分页指示器:显示当前图片的位置和总图片数量。
  • 触摸反馈:滑动时提供视觉或触觉反馈。

应用场景

  • 网站首页的广告展示。
  • 应用的启动画面或欢迎界面。
  • 电商平台的商品推荐。

常见问题及解决方法

  1. 滑动不流畅
    • 原因:可能是由于页面加载的资源过多,导致渲染卡顿。
    • 解决方法:优化图片大小,减少DOM元素,使用CSS3硬件加速。
  • 触摸事件无响应
    • 原因:可能是JavaScript代码中触摸事件绑定不正确或冲突。
    • 解决方法:检查事件绑定代码,确保没有其他脚本阻止了默认行为。
  • 自动播放功能失效
    • 原因:可能是由于页面可见性变化(如切换到后台)导致定时器停止。
    • 解决方法:使用visibilitychange事件监听页面可见性,并相应地控制自动播放。

示例代码: 以下是一个简单的触屏滑动banner的JavaScript实现示例:

代码语言:txt
复制
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Touch Slider</title>
<style>
  .slider {
    width: 100%;
    overflow: hidden;
    position: relative;
  }
  .slider-container {
    display: flex;
    transition: transform 0.3s ease;
  }
  .slider-container img {
    width: 100%;
    flex-shrink: 0;
  }
</style>
</head>
<body>

<div class="slider" id="slider">
  <div class="slider-container" id="sliderContainer">
    <img src="image1.jpg" alt="Image 1">
    <img src="image2.jpg" alt="Image 2">
    <img src="image3.jpg" alt="Image 3">
  </div>
</div>

<script>
  const sliderContainer = document.getElementById('sliderContainer');
  let startX = 0;
  let currentTranslate = 0;
  let prevTranslate = 0;
  let animationID = 0;
  let currentIndex = 0;

  sliderContainer.addEventListener('touchstart', touchStart);
  sliderContainer.addEventListener('touchmove', touchMove);
  sliderContainer.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 < 2) currentIndex += 1;
    if (movedBy > 100 && currentIndex > 0) currentIndex -= 1;
    prevTranslate = currentTranslate;
    setSliderPosition();
  }

  function setSliderPosition() {
    sliderContainer.style.transform = `translateX(-${currentIndex * 100}%)`;
  }
</script>

</body>
</html>

这个示例展示了如何创建一个基本的触屏滑动banner,包括触摸事件的监听和处理,以及图片容器的位置更新。

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

相关·内容

Bootstrap幻灯轮播如何支持触屏左右滑动手势?

bootstrap是封装好的框架,需要某些功能只需调用相应的组件就可以,但有些还是没加入,比如幻灯轮播触屏左右滑动手势就不支持,大家用的设备基本是触屏的了,能用滑动交互在小屏幕上体验会更好,那么如何实现呢...一个比较简单的方法是增加一个滑动手势js插件:hammer.js,网上有很多cdn调用地址,像//cdn.bootcss.com/hammer.js/2.0.8/hammer.min.js,我们在head...Next   关键的步骤来了,我们需要写一个javascript命令调用hammer.js...需要注意的是,jquery版本最好是1.9版本的jquery-1.9.1.min.js,否则可能在电脑上可以实现手势滑动,而在手机上无法触摸滑动   javascript命令这个是关键,不会写不会改就不好玩了

3.7K50
  • 触屏事件

    触屏事件概述 移动端浏览器兼容性较好,我们不需要考虑以前 JS 的兼容性问题,可以放心的使用原生 JS 书写效果,但是移动端也有自己独特的地方。...比如触屏事件 touch(也称触摸事件),Android和 IOS 都有。 touch 对象代表一个触摸点。触摸点可能是一根手指,也可能是一根触摸笔。...触屏事件可响应用户手指(或触控笔)对屏幕或者触控板操作。 常见的触屏事件如下: ? 2....然后用盒子原来的位置 + 手指移动的距离 手指移动的距离: 手指滑动中的位置 减去 手指刚开始触摸的位置 拖动元素三步曲: (1) 触摸元素 touchstart: 获取手指初始坐标,同时获得盒子原来的位置...(2) 移动手指 touchmove: 计算手指的滑动距离,并且移动盒子 (3) 离开手指 touchend: 注意: 手指移动也会触发滚动屏幕所以这里要阻止默认的屏幕滚动 e.preventDefault

    79341

    触屏事件

    1触屏事件 1.1. 触屏事件概述 移动端浏览器兼容性较好,我们不需要考虑以前 JS 的兼容性问题,可以放心的使用原生 JS 书写效果,但是移动端也有自己独特的地方。...比如触屏事件 touch(也称触摸事件),Android和 IOS 都有。 touch 对象代表一个触摸点。触摸点可能是一根手指,也可能是一根触摸笔。...触屏事件可响应用户手指(或触控笔)对屏幕或者触控板操作。 常见的触屏事件如下: 1.3.2....(2) 移动手指 touchmove: 计算手指的滑动距离,并且移动盒子 (3) 离开手指 touchend: 注意: 手指移动也会触发滚动屏幕所以这里要阻止默认的屏幕滚动 e.preventDefault... // (1) 触摸元素touchstart : 获取手指初始坐标,同时获得盒子原来的位置 // (2) 移动手指 touchmove :计算手指的滑动距离

    73820

    JavaScript——触屏事件

    概述 移动端浏览器兼容性较好,我们不需要考虑以前js的兼容性问题,可以放心的使用原生js书写效果,但是移动端也有自己独特的地方。比如触屏事件touch(也称触摸事件),Android和IOS都有。...触屏事件可响应用户手指(或触控笔)对屏幕或者触控板操作。...常见的触屏事件如下: 触屏touch事件 说明 touchstart 手指触摸到一个DOM元素时触发 touchmove 手指在一个DOM元素上滑动时触发 touchend 手指从一个DOM元素上移开时触发...触摸事件对象 TouchEvent是一类描述手指在触摸平面(触摸屏、触摸板等)的状态变化事件。... // (1) 触摸元素 touchstart: 获取手指初始坐标,同时获得盒子原来的位置 // (2) 移动手指 touchmove: 计算手指的滑动距离

    2.1K10

    SwipeRefreshLayout嵌套banner滑动冲突

    banner是一个第三方轮播库,到现在为止已经有8000+的star了,使用的人也很多。使用的人越多,业务场景就越多,相应的问题也会越多。...比如SwipeRefreshLayout嵌套banner的时候,就会使banner手动滑动起来特别的费劲,经常滑不过去。...https://github.com/youth5201314/banner 思路: 因为下拉刷新,只有纵向滑动的时候才有效,只需要判断此时是纵向滑动还是横向滑动就可以了。...纵向滑动就拦截事件,横向滑动不拦截。 怎么判断是纵向滑动还是横向滑动,只要判断Y轴的移动距离大于X轴的移动距离那么就判定为纵向滑动就行了。...因为下拉刷新,只有纵向滑动的时候才有效,只需要判断此时是纵向滑动还是横向滑动就可以了。 * 2. 纵向滑动就拦截事件,横向滑动不拦截。 * 3.

    85410

    移动端触屏事件

    触屏事件概述 移动端浏览器兼容性较好,我们不需要考虑以前 JS 的兼容性问题,可以放心的使用原生 JS 书写效果,但是移动端也有自己独特的地方。...比如触屏事件 touch(也称触摸事件),Android和 IOS 都有。 touch 对象代表一个触摸点。触摸点可能是一根手指,也可能是一根触摸笔。...触屏事件可响应用户手指(或触控笔)对屏幕或者触控板操作。 常见的触屏事件如下: ? 2....然后用盒子原来的位置 + 手指移动的距离 手指移动的距离:  手指滑动中的位置 减去  手指刚开始触摸的位置 拖动元素三步曲: (1) 触摸元素 touchstart: 获取手指初始坐标,同时获得盒子原来的位置...(2) 移动手指 touchmove: 计算手指的滑动距离,并且移动盒子 (3) 离开手指 touchend: 注意: 手指移动也会触发滚动屏幕所以这里要阻止默认的屏幕滚动 e.preventDefault

    2.9K30

    移动端轮播图笔记

    1.触屏事件 1.1触屏事件概述 移动端浏览器兼容性好,我们不需要考虑以前JS的兼容问题,可以放心使用原生JS书写效果,但是移动端也有自己独特的地方,比如触屏事件touch(也叫触摸事件),Android...触屏事件可以相应用户手指对屏幕或者触控板操作 常见的触屏事件: 1.touchstart:手指触摸到一个DOM元素时触发 2.touchmove:手指在一个DOM元素上滑动时触发 3.touchend:...,根据移动距离去判断是回弹还是播放上一张下一张 5.如果移动距离小于某个像素 就回弹 6.如果移动距离大于某个像素就上一张或者下一张 js代码: //1.获取元素 var...banner = document.querySelector(".banner"); var ul = document.querySelector(".banner ul"); var...ol = document.querySelector(".banner ol"); //获取banner的宽度 var w = banner.offsetWidth; //2

    2.5K21

    Appium常用操作之「微信滑屏、触屏操作」

    目录 一、滑屏操作 1.访问之后,马上就滑屏可以吗? 2.连续实现 2 次滑屏 3.代码 二、模拟触屏 1.短按和点击的区别? 2.用坐标还是元素?...如果直接滑动 2 次,第一次滑动效果还没展示出来就直接滑动第二次了,就会看到看不懂得现象。所以这种情况下就要加上time。...driver.swipe(start_x,start_y,end_x,end_y,300) time.sleep(2) driver.swipe(start_x,start_y,end_x,end_y,300) 二、模拟触屏...[图片来自网络] 滑屏也是触屏实现的。...滑屏操作是在屏幕上按住一个点,然后滑动到另外一个点,最后把它松掉。 九宫格就是个典型的触屏应用。 [图片来自网络] 2.用坐标还是元素? 元素方便简单,但是不是你想选就一定是哪一种。

    1.6K20

    Appium常用操作之「微信滑屏、触屏操作」

    目录 一、滑屏操作 1.访问之后,马上就滑屏可以吗? 2.连续实现 2 次滑屏 3.代码 二、模拟触屏 1.短按和点击的区别? 2.用坐标还是元素?...滑屏操作需要时间,模拟器或者真机执行操作更需要时间。如果直接滑动 2 次,第一次滑动效果还没展示出来就直接滑动第二次了,就会看到看不懂的现象。所以这种情况下就要加上time。...driver.swipe(start_x,start_y,end_x,end_y,300) time.sleep(2) driver.swipe(start_x,start_y,end_x,end_y,300) 二、模拟触屏...图片来自网络 滑屏也是触屏实现的。手指在屏幕上点点点,在 Appium 中提供了专门的TouchAction类来做这件事。 Press、longPress和release组合起来使用的。...滑屏操作是在屏幕上按住一个点,然后滑动到另外一个点,最后把它松掉。 「九宫格」就是个典型的触屏应用。 ? 图片来自网络 2.用坐标还是元素? 元素方便简单,但是不是你想选就一定是哪一种。

    2.1K20

    升级版IPS全贴合触屏相比传统TN+触屏的优势在哪里?

    为了简化屏和板的组装过程,提高生产效率,在原先TN+触屏的基础上,推出了升级版的IPS全贴合触屏,弥补了传统触屏组装麻烦、延展性弱、成本高等缺点。...那么,升级版的IPS全贴合触屏相对于传统的TN+触屏的优势主要体现在哪里呢?...传统板+屏开发板:品名:WT32-SC01MCU: ESP32尺寸:3.5"分辨率:480*320屏幕类型:TN+触屏外型尺寸:91*58*12MM屏幕接口:SPIFlash:内置4MB SPI Flash...TN+触屏产品的优势对比:常规产品的板+屏:1、板屏贴合,需外加铁框,美感会差很多;2、组装麻烦,板与用户产品外壳需用螺丝固定,影响生产效率;3、常规产品为了方便固定,PCB板会比屏大,成本高;4、常规产品天线紧贴屏幕...升级后的IPS全贴合触屏:1、添加了结构支架,组装方便,通过卡扣,可与用户的产品完美结合 ;2、主板面积小,固定方便,节省空间和成本;3、串口屏固定可由外往里安装,与用户产品外壳完美结合;4、散热好;5

    2.1K00

    两周“学会”bootstrap搭建一个移动站点

    一直想着用bootstrap搭建网站,它的自适应、元素封装完善、现成的Glyphicons字体图标,省去很多的css、js、ui的工作,可以快速搭建一个客户需要的站点。...国内的企业站一般都喜欢这样的版式:头部导航、幻灯片banner、次导航、文章列表、tag标签、转化引导、主业分类、团队介绍、联系方式,那我们就按这样设计   1.按照bootstrap中文网bootcss.com...官方文档,首先我们先引用css和js,用大的body把页面包围起来   2.用导航条设计一个头部导航,用栅格系统column分为散列,左侧是主页小房子标志,中间是logo,右侧是下拉导航菜单...  3.用carousel.js做一个幻灯片轮播,如果想加入手势滑动效果参考ytkah之前写的这篇文章:Bootstrap幻灯轮播如何支持触屏左右滑动手势?

    2.9K60
    领券