位置: 编程技术 - 正文

javascript单页面手势滑屏切换原理详解(javascript页面设计)

编辑:rootadmin

推荐整理分享javascript单页面手势滑屏切换原理详解(javascript页面设计),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:原生js实现单页面,jquery 单页应用,javascript首页,javascript首页,jquery 单页面,jquery 单页面,jquery 单页面,原生js实现单页面,内容如对您有帮助,希望把文章链接给更多的朋友!

H5单页面手势滑屏切换是采用HTML5 触摸事件(Touch) 和 CSS3动画(Transform,Transition)来实现的,效果图如下所示,本文简单说一下其实现原理和主要思路。

1、实现原理

假设有5个页面,每个页面占屏幕%宽,则创建一个DIV容器viewport,将其宽度(width) 设置为%,然后将5个页面装入容器中,并让这5个页面平分整个容器,最后将容器的默认位置设置为0,overflow设置为hidden,这样屏幕就默认显示第一个页面。

CSS样式:

注册touchstart,touchmove和touchend事件,当手指在屏幕上滑动时,使用CSS3的transform来实时设置viewport的位置,比如要显示第二个页面,就设置viewport的transform:translate3d(%,0,0) 即可, 在这里我们使用translate3d来代替translateX,translate3d可以主动开启手机GPU加速渲染,页面滑动更流畅。

2、主要思路

从手指放在屏幕上、滑动操作、再到离开屏幕是一个完整的操作过程,对应的操作会触发如下事件:

手指放在屏幕上:ontouchstart

javascript单页面手势滑屏切换原理详解(javascript页面设计)

手指在屏幕上滑动:ontouchmove

手指离开屏幕:ontouchend

我们需要捕获触摸事件的这三个阶段来完成页面的滑动:

ontouchstart: 初始化变量, 记录手指所在的位置,记录当前时间

ontouchmove: 获得当前所在位置,计算手指在屏幕上的移动差量deltaX,然后使页面跟随移动

ontouchend:手指离开屏幕时,计算屏幕最终停留在哪一页。首先计算手指在屏幕上的停留时间deltaT,如果deltaT<ms,则认为是快速滑动,相反则是慢速滑动,快速滑动和慢速滑动的处理是不同的:

(1)如果是快速滑动,则让当前页面完整的停留在屏幕中央(需要计算当前页面还有多少需要滑动)

(2)如果是慢速滑动,还需要判断手指在屏幕上滑动的距离,如果滑动的距离没有超过屏幕宽度%,则要回退到上一页,相反则要停留在当前页面

除此之外,还要计算当前页面是第几页,并设置当前页码

基本的思路就这些,当然在实际操作过程中还有一些细节需要注意,这里就不详细说了,都在代码里能体现出来,源代码已传至Git: 有兴趣的同学欢迎一起讨论。

JS DOM实现鼠标滑动图片效果 经常,我们在浏览各种网页的时候,都会有各种动画效果展示,像下图所示的是很多网上商城常用的货品展示方式,同类的货品并排展现在窗口上,用

关于JS中match() 和 exec() 返回值和属性的测试 语法:exec():RegExpObject.exec(string)match():stringObject.match(string)stringObject.match(regexp)知识点:exec()是RegExp对象的方法,而match()是String对象的方法。都会返回

使用Sticky组件实现带sticky效果的tab导航和滚动导航的方法 sticky组件,通常应用于导航条或者工具栏,当网页在某一区域滚动的时候,将导航条或工具栏这类元素固定在页面顶部或底部,方便用户快速进行这类

标签: javascript页面设计

本文链接地址:https://www.jiuchutong.com/biancheng/377444.html 转载请保留说明!

上一篇:简述Matlab中size()函数的用法(简述matlab中控制系统的数学描述类型)

下一篇:JS DOM实现鼠标滑动图片效果(js鼠标滚动页面触发事件)

  • 期末未缴税额为负数怎么调整
  • 山西省税务申报网站
  • 消费税组成计税价格怎么理解
  • 中级会计实务主观题
  • 小规模的开专票怎么征税
  • 工程类工资表为哪些内容
  • 劳务派遣公司必须设立股东
  • 终止经营的会计处理
  • 企业购买理财都需先交税再提现吗
  • 资产总额季度平均值计算公式
  • 现金流量净额正负
  • 当月开票没有收到钱
  • 维保税率和维修税率是多少
  • 收到快递费属于什么科目
  • 公司零申报怎么注销
  • 厂房面积测绘收费标准
  • 固定资产已入账怎么冲销
  • 企业收到的政府补贴,怎么入账
  • 堤围内的土地性质
  • 押金满一年才能退
  • 我公司只开了普票未开专票是否需要发票认证?
  • 失控进项发票转出 补税做账
  • 公司企业变更后原来的营业执照还有吗
  • 内蒙古地税电子税务局app
  • 小规模纳税人核定征收标准
  • 增值是什么意思解释
  • 生产负荷的计算
  • 本月合计怎么做
  • 作废代开发票,是否退还已纳税款?
  • 缴纳残保金和工龄有关吗
  • 机动车销售统一专票税率
  • 扣缴单位无有效税种认定什么意思
  • 厂区道路施工步骤
  • 反射调用set方法
  • 债权转增资本公积账务处理
  • 佣金代扣代缴增值税需要缴纳附加税吗
  • PHP:Memcached::setByKey()的用法_Memcached类
  • 企业年金基金收支情况
  • PHP:imagecolortransparent()的用法_GD库图像处理函数
  • 挪威罗弗敦岛
  • php定义一个二维数组
  • laravel orm使用
  • CLIP(Contrastive Language-Image Pre-Training)简介
  • 持有至到期投资账务处理
  • 用jsp实现用户登录验证
  • unistack怎么关掉
  • 股权出质有时间限制吗
  • mysql读写分离amoeba
  • 递延收益为什么是递延所得税资产
  • 固定资产里含有增值税吗
  • 不含税货款要开发票怎么弄
  • 建筑业成本核算流程
  • 关联企业无息借款如何征税?
  • 固定资产后续支出一律计入固定资产成本
  • 累计摊销属于什么类科目
  • 契税的计税金额是什么
  • 收到代理服务费怎么做分录呢
  • 未达起征点怎么报税
  • 销售收入用营业收入还是营业总收入
  • 一个完整的活动策划方案范文
  • cmd命令行操作
  • mac蓝牙连接iphone有什么用
  • linux版flash
  • freebsd11.3安装教程
  • ubuntu chmod
  • nacos监控服务
  • muamgr.exe - muamgr是什么进程 有何作用
  • win8.1玩游戏好不好
  • ,linux
  • c#+unity3d
  • js中sort排序
  • Open quote is expected for attribute "name" associated with an element type "item".
  • Node.js中的全局对象有
  • 关于jquery的描述错误的是
  • 面向对象的三大特征
  • 如何查询个体工商户是查账征收还是核定征收
  • 福建电子发票开票流程?
  • 天津2023防暑降温费标准文件
  • 石家庄有线电视客服电话9688
  • 江西省税务局官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设