您现在的位置是:网站首页> 编程资料编程资料
HTML5单页面手势滑屏切换原理 html5实现点击弹出图片功能html5 录制mp3音频支持采样率和比特率设置html5表单的required属性使用html5调用摄像头实例代码HTML5页面音频自动播放的实现方式Html5大屏数据可视化开发的实现html实现弹窗的实例HTML5来实现本地文件读取和写入的实现方法HTML 罗盘式时钟的实现HTML5简单实现添加背景音乐的几种方法
2023-10-13
340人已围观
简介 H5单页面手势滑屏切换是采用HTML5 触摸事件(Touch) 和 CSS3动画(Transform,Transition)来实现的,接下来通过本文给大家介绍HTML5单页面手势滑屏切换原理 ,需要的朋友一起学习吧
H5单页面手势滑屏切换是采用HTML5 触摸事件(Touch) 和 CSS3动画(Transform,Transition)来实现的,效果图如下所示,本文简单说一下其实现原理和主要思路。
1、实现原理
假设有5个页面,每个页面占屏幕100%宽,则创建一个DIV容器viewport,将其宽度(width) 设置为500%,然后将5个页面装入容器中,并让这5个页面平分整个容器,最后将容器的默认位置设置为0,overflow设置为hidden,这样屏幕就默认显示第一个页面。
- <div id="viewport" class="viewport">
- <div class="pageview" style="background: #3b76c0" >
- <h3 >页面-1h3>
- div>
- <div class="pageview" style="background: #58c03b;">
- <h3>页面-2h3>
- div>
- <div class="pageview" style="background: #c03b25;">
- <h3>页面-3h3>
- div>
- <div class="pageview" style="background: #e0a718;">
- <h3>页面-4h3>
- div>
- <div class="pageview" style="background: #c03eac;">
- <h3>页面-5h3>
- div>
- div>
CSS样式:
- .viewport{
- width: 500%;
- height: 100%;
- display: -webkit-box;
- overflow: hidden;
- pointer-events: none;
- -webkit-transform: translate3d(0,0,0);
- backface-visibility: hidden;
- position: relative;
- }
注册touchstart,touchmove和touchend事件,当手指在屏幕上滑动时,使用CSS3的transform来实时设置viewport的位置,比如要显示第二个页面,就设置viewport的transform:translate3d(100%,0,0) 即可, 在这里我们使用translate3d来代替translateX,translate3d可以主动开启手机GPU加速渲染,页面滑动更流畅。
2、主要思路
从手指放在屏幕上、滑动操作、再到离开屏幕是一个完整的操作过程,对应的操作会触发如下事件:
手指放在屏幕上:ontouchstart
手指在屏幕上滑动:ontouchmove
手指离开屏幕:ontouchend
我们需要捕获触摸事件的这三个阶段来完成页面的滑动:
ontouchstart: 初始化变量, 记录手指所在的位置,记录当前时间
- /*手指放在屏幕上*/
- document.addEventListener("touchstart",function(e){
- e.preventDefault();
- var touch = e.touches[0];
- startX = touch.pageX;
- startY = touch.pageY;
- initialPos = currentPosition; //本次滑动前的初始位置
- viewport.style.webkitTransition = ""; //取消动画效果
- startT = new Date().getTime(); //记录手指按下的开始时间
- isMove = false; //是否产生滑动
- }.bind(this),false);
ontouchmove: 获得当前所在位置,计算手指在屏幕上的移动差量deltaX,然后使页面跟随移动
- /*手指在屏幕上滑动,页面跟随手指移动*/
- document.addEventListener("touchmove",function(e){
- e.preventDefault();
- var touch = e.touches[0];
- var deltaX = touch.pageX - startX;
- var deltaY = touch.pageY - startY;
- //如果X方向上的位移大于Y方向,则认为是左右滑动
- if (Math.abs(deltaX) > Math.abs(deltaY)){
- moveLength = deltaX;
- var translate = initialPos + deltaX; //当前需
相关内容
- HTML5 画布canvas使用方法使用分层画布来优化HTML5渲染的教程html5画布旋转效果示例用html5的canvas画布绘制贝塞尔曲线完整代码html5的画布canvas——画出简单的矩形、三角形实例代码html5的画布canvas——画出弧线、旋转的图形实例代码+效果图HTML5边玩边学(1)画布实现方法 Html5画布_动力节点Java学院整理
- 【HTML5】Canvas绘制简单图片教程HTML5实现的轻量级绘制SVG轮廓线路径动画插件特效源码html5 实现客户端验证上传文件的大小(简单实例)html5基于鼠标滚动控制植树生长动画特效源码HTML5实现页面切换激活的PageVisibility API使用初探HTML5的Geolocation地理位置定位API使用教程HTML5中的强制下载属性download使用实例解析HTML5事件方法全部汇总HTML5全屏响应式缩放切换幻灯片代码深入理解HTML的FormData对象
- 全民英雄闪退的原因分析及解决方法_手机游戏_游戏攻略_
- 天天酷跑 期末考试试题题目一览_手机游戏_游戏攻略_
- 爸爸去哪儿黑屏闪退 具体解决方法分享_手机游戏_游戏攻略_
- 全民英雄 敌法师阵容搭配技巧全面解析_手机游戏_游戏攻略_
- 全民英雄 智力英雄装备推荐一览表_手机游戏_游戏攻略_
- 爸爸去哪儿 无限刷体力图文攻略_手机游戏_游戏攻略_
- 刺客信条:海盗传奇 内购存档修改方法详解_手机游戏_游戏攻略_
- 爸爸去哪儿 第2关-做午饭 三星通关图文攻略_手机游戏_游戏攻略_
点击排行
本栏推荐
