位置: 编程技术 - 正文

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鼠标滚动页面触发事件)

  • 政府补贴的账务属于哪个科目
  • 注册商标费用计算方法
  • 公司举办年会的要求有哪些
  • 个人商业保险抵交个人所得税
  • 税务部门罚没收入200元
  • 12月份的收入1月份开具发票,报税时免税吗
  • 公司办的中石化油卡可以查视频记录吗
  • 增值税抵扣凭证管理
  • 应交增值税期末余额在借方表示什么
  • 预缴税款个人所得税如何计算
  • 关于支付税审费的问题
  • 房地产开发经营属于什么行业类别
  • 处于成熟期的企业其预算模式的特点是以什么为起点
  • 免税和退税的区别出口企业
  • 内部交易的会计分录
  • 工资发错了,多发了怎么办
  • 上一年度多交年度所得税可以退税吗
  • 借主营业务成本表示什么
  • 购买的商业保险可以税前扣除吗
  • 开具发票的收入如何做账务处理?
  • 什么情况下出租人可以解除合同
  • 发票的概念
  • qbdagent2002.exe - qbdagent2002是什么进程 有什么用
  • 我告诉你win7旗舰版
  • 一叶兰的养殖方法和注意事项有哪些
  • 企业可以超范围经营吗
  • 限售股是好是坏
  • 国有划拨土地给集体企业怎么办
  • 瑞士伯尔尼小镇
  • 个人独资企业建筑类怎么注册
  • python删除nan
  • python del语法
  • 社保滞纳金计入个人账户吗
  • 详解帝国cms图集大全
  • 个人注册公司是否可以免税
  • 工程材料发票备注要求
  • 社保是当月计提当月交吗
  • 销售退回怎么写分录
  • 残保金会计分录人员经费
  • 委托收款和托收承付结算流程图
  • 什么叫固定资产
  • 房地产企业实际发生的税金及附加
  • 普通进项发票怎么做分录
  • 哪种飞机票可以抵扣进项税
  • 内部交易内部交易收益造成的当期折旧的多计额
  • 滞留票不处理可以么
  • 发票已开的情况下不确认收入可以吗?
  • 在途物资和材料采购的区别
  • sqlserver数据库建库建表
  • sqlserver数据完整性
  • winxp更新到win10
  • 使用linux常用命令
  • centos升级命令
  • ubuntu无线网卡驱动离线安装
  • windows7无法启动怎么修复
  • 安装win7/Win10双系统,磁盘如何分区?
  • linux怎么禁用用户
  • cocos2dx怎么读
  • cocos2dx webview
  • [置顶]bilinovel
  • ComboBox 和 DateField 在IE下消失的解决方法
  • nodejs web3
  • opengl transform
  • 在android的activity活动中
  • html+css网站设计基础教程
  • unity自动生成
  • iframe的替代方案
  • shell ui
  • java 同步方法和同步代码块区别
  • js utf-8编码转换中文
  • 详解javascript事件冒泡
  • android 简历模板
  • 风险研判能力不足的原因
  • 2020年职工探亲路费报销最新规定
  • 退休人员还写工作单位吗
  • 半挂牵引车车船税怎么算
  • 国税发票如何查询真伪
  • 天津车辆购置税网上办税
  • 资源税什么时候征收
  • 北京市朝阳区地税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设