移动开发实践及坑总结

做过很多移动端的项目,在开发调试过程中,一款好的调试工具会让效率大大提高。更多的一些知识点,大家可以看看兄弟连官方论坛.

下面,就总结一下移动端遇见的坑。

1.iphone动态生成html元素click失效

这个也是神奇的坑,找了很久资料,也没有很原理的解释。

解决方法:  为绑定click的元素增加css样式   cursor:pointer;

2.lineheight

line-height经常用于文字居中,不同手机显示效果不一样。什么鬼~

在chrome模拟器上又是显示得非常完美,但是!Android和IOS又各自‘偏移’了。如果把line-height加1px,iPhone文字就会稍微‘正常显示’,由于我们app的ios用户居多,并且android机型太多,不同机型也会显示不同,所以只能退而求其次了。line-height的兼容问题不太好解决,容器高度越小,显示效果的差距越明显。

解决方案:稍微大一点的高度,最好把line-height设置为高度+1px,两个平台显示都不会太奇怪

9.移动端手势

手指放在屏幕上:ontouchstart     手指在屏幕上滑动:ontouchmove      手指离开屏幕:ontouchend

原理:

1.在touchstart事件触发时,  记录手指按下的时间startTime,本次滑动的初始位置initialPos。

2.在touchmove事件触发时,记录当前位置nowPosition(实时移动元素),滑动距离movePosition(当前位置nowPosition与初始位置initialPos的差值),判断正负数再决定是左还是右移动。

3.在touchend事件触发时,   记录手指离开屏幕的时间endTime,获得手指在屏幕上停留的时间(endTime-startTime),滑动距离movePosition

·        判断是否滑动:

1.   如果停留时间少于300ms,则认为是快速滑动,无论滑动距离是多少,都到下一页

2.   滑动距离与‘容器’  大小进行比较,若超过‘容器’大小的1/3,则到下一页

4.实现自定义原生控件的样式

由于select移动端原生样式很丑,但是原生弹出样式是符合我们设计的原则

解决方法:将原本select 设置为透明,z-index设置高~再用一个比较好看的样式‘假装’在表面

5.移动端使用innerHtml绘制

使用innerHTML绘制大段,之后想获取HTML的ID节点,事实上是获取不到的,这种问题在动态创建DOM会经常发生

这也是一个神器的问题,博主自己写了一个移动端轮播插件,在chrome上浏览非常正常,但到了真机上却显示空白,各种百度,最后才发现这么坑的地方…

解决方案:尝试了很多方法之后,老老实实在页面直接用html结构,如果有更好的方法,也请告诉我。

6.300ms延迟

·        方案一:禁用缩放

在HTML文档头部包含如下meta标签时:

<meta name="viewport" content="user-scalable=no"/>

<meta name="viewport" content="initial-scale=1,maximum-scale=1"/>

缺点------就是必须通过完全禁用缩放来达到去掉点击延迟的目的,然而完全禁用缩放并不是我们的初衷,我们只是想禁掉默认的双击缩放行为,这样就不用等待300ms来判断当前操作是否是双击。

·        方案二:更改默认的视口宽度

<meta name="viewport" content="width=device-width"/>

如果设置了上述meta标签,那浏览器就可以认为该网站已经对移动端做过了适配和优化,就无需双击缩放操作了。
这个方案相比方案一的好处在于,它没有完全禁用缩放,而只是禁用了浏览器默认的双击缩放行为,但用户仍然可以通过双指缩放操作来缩放页面。

 

兼容性问题:

对于方案一和方案二,Chrome是率先支持的,Firefox紧随其后,然而令Safari头疼的是,它除了双击缩放还有双击滚动操作,如果采用这种两种方案,那势必连双击滚动也要一起禁用。

7.点击穿透

问题常见发生场景:假如页面上有两个元素A和B。B元素在A元素之上。我们在B元素的touchstart事件上注册了一个回调函数,该回调函数的作用是隐藏B元素。我们发现,当我们点击B元素,B元素被隐藏了,随后,A元素触发了click事件。

这是因为在移动端浏览器,事件执行的顺序是touchstart > touchend > click

而click事件有300ms的延迟,touchstart事件把B元素隐藏之后,隔了300ms,浏览器触发了click事件,但是此时B元素不见了,所以该事件被派发到了A元素身上。如果A元素是一个链接,那此时页面就会意外地跳转。

解决思路:

1.不要混用touch和click

2.消耗掉touch之后的click

解决方法:

1.只用touch   把页面内所有click全部换成touch事件( touchstart 、’touchend’、’tap’),注意:a标签的href也是click,需要换成js的跳转。

2.改动最小——350ms后再隐藏B元素

8. 虚拟键盘导致fixed元素错位

fixed元素一定会伴随虚拟键盘的出现,但是虚拟键盘只是“贴”在了viewport上,表面上不会对dom产生“任何”影响,但是这个时候fixed元素表现却变得怪异起来,会错位。

解决原理:虚拟键盘弹出时将fixed元素设置为static,虚拟键盘消失时候设置回来。

解决方案:由于虚拟键盘出现并未抛出事件,而检测scroll或者resize事件,皆会有一定延迟,会出现闪烁现象。则当前获取焦点元素为文本元素,就将fixed元素设置为static。

兄弟连感谢在此感谢大家的观看.

时间: 2024-10-06 14:24:11

移动开发实践及坑总结的相关文章

移动开发实践及‘坑’总结

1.input   placeholder问题 在chrome 模拟移动端调试时[左边图],显示的非常正常,但是在真机上[右边图],placeholder里面的内容明显靠上,非常的不美观      在国外网站,对这个属性的兼容性处理,那就是不要设计input的line-height或者设置line-height为normal即可, 试了一下,虽然在谷歌模拟调试里稍微偏上,但是在"真机上"正常垂直居中- 2.line-height line-height经常用于文字居中,不同手机显示效果

软件开发的那些坑-目标的重要性

项目上线有一段时间了,上线后大家忙着改bug,忙着汇报,忙着二期的规划,一直没有坐下来一起聊聊. 上周,我还是决定花费大家半天的时间,组织开了迭代回顾会. 迭代回顾会对于敏捷来讲,是一个很重要的实践,但其实不提敏捷的时候,我们也在做,只是有个更普通的名字,叫项目总结会.(迭代回顾会的实践方法见文章最后) 会上,当我们回顾了项目过程时,发现一个重要问题,这个问题就是:经常性的,我们忽略了或忘了目标,这里的目标应该有但不限于以下内容. 一. 业务目标 说出来,大家可能都觉得不可思议,没有目标,那项目

敏捷开发实践总结?EUMs

为了更好的阅读体验,欢迎访问 作者博客原文 项目回顾 项目背景 EUMs(End User Monitor System)是一个在线的物资跟踪监控系统.由ThoughtWorks团队为Unicef(United Nations International Children's Emergency Fund,联合国儿童基金会,客户)提供的一套完善的软件交付服务. 该系统为资助物资的跟踪与监控提供了完整的网络解决方案.整个流程涵盖了Unicef对物资来源的管控.库存管理.物资下发与跟踪.Unicef

cesiumjs开发实践(七) 3D模型

cesium中支持载入3D模型,不过只支持gltf格式.gltf是khronos组织(起草OpenGL标准的那家)定义的一种交换格式,用于互联网或移动设备上展现3d内容,充分支持opengl,webgl,opengles图形加速标准. gltf目前可以由collada格式转换而来,官网上也提供了一个转换工具(https://www.khronos.org/gltf).这个工具比较坑爹,只能和collada文件放在同一个目录才工作,转换后的结果文件也必须在同一目录,就是说不能指定输入和输出路径,当

&lt;&lt;Python编程:从入门到实践&gt;&gt;踩坑记 Django

<<Python编程:从入门到实践>>踩坑记 Django Django Python 19.1.1.5 模板new_topic 做完书上的步骤后,对主题添加页面经行测试,但是浏览器显示 服务器异常. 个人采用的开发环境是virtual studio code , 测试起来很是难受,因为我配置的debug环境,断点操作没有作用. 经过我不断的测试,才发现我失败的原因是由于之前的误操作,先建立new_pizzas.py后改为new_pizzas.html的,错误就在这里.在我之后新建

【小程序】微信小程序开发实践

帐号相关流程 注册范围 企业 政府 媒体 其他组织 换句话讲就是不让个人开发者注册. :) 填写企业信息 不能使用和之前的公众号账户相同的邮箱,也就是说小程序是和微信公众号一个层级的. 填写公司机构信息,对公账户信息 绑定管理员微信 企业认证 公司对公账户对微信进行打款 账户自动验证后,自动认证通过,并将认证资金退回公司对公账户,费用在1元内随机 小程序发布流程 开发实践 这次的demo项目为农历和公历的转换器,重在体验开发流程. AppID(小程序ID) 做上面的那些步骤就是为了得到小程序ID

使用ADO实现BLOB数据的存取 -- ADO开发实践之二

使用ADO实现BLOB数据的存取 -- ADO开发实践之二 http://www.360doc.com/content/11/0113/16/4780948_86256633.shtml 一.前言 在上一篇文章<>中我们详细介绍了ADO基本的操作方法,在实际的开发过程中我们常常需要存储较大的二进制数据对象,比如:图像.音频文件.或其它二进制数据,这些数据我们称之为二进制大对象BLOB(Binary Large Object),其存取的方式与普通数据有所区别.本文将介绍利用ADO在数据库中存取B

【新书推荐】《微软开源跨平台移动开发实践》带你走近微软开源开源跨平台技术

上周收到本书作者李争送的一本12月份的新书<微软开源跨平台移动开发实践——利用ASP.NET Core 1.0 .Apache Cordova.Xamarin和Azure快速构建移动应用解决方案>.这本书的名字超长.这本书也是超薄,只有220页,一个周末时间就读完了,但是这本书的内容确是超丰富,浓缩了微软这三年向开源和跨平台领域的转变,微软在开源和跨平台领域构建出来的一套技术体系.从服务端的NET Core.ASP.NET 和 Web APi ,到Web端的 Typescript脚本语言,再到

Android开发实践:Android交叉编译工具链的使用

前面2篇文章分别介绍了Android NDK编译的命令行参数,以及如何在任意目录使用Android.mk来编译本地c/c++代码,Andriod.mk和ndk-build只不过是Android官方提供了一套封装过的Android交叉编译环境而已,其实,你可以不用它,而直接通过传统的Makefile文件来编译你的c/c++代码的,本文即介绍如何直接通过传统的Makefile文件来编译可用于Android平台的库文件. 经常搞嵌入式开发的朋友对于交叉编译环境应该并不陌生,说白了,就是一组运行在x86