Hybrid App就是混合式App了,简单点说就是原生App里打开webApp,相当于原生给你提供了一个浏览器内核能够打开你的页面,那么问题来了,如果你的web页面交互比较多会有很多兼容问题,下面我就来列举一下。(以下很多bug在手机浏览器里都不存在,只是在App里面打开才会存在)。
1、在iOS系统里,也就是苹果App上,现在有一个按钮,点击按钮会弹出一个文本框,用户可以在文本框输入,但是为了有更好的体验,在点击按钮的时候会给文本框添加一个获取焦点事件,这样用户点击完按钮就可以直接输入而不需要再点一下文本框才能输入,但是如果你的页面上如果有定位的话就容易失效,特别是position:fixed,获取焦点事件会让fixed失效,导致页面排版出现问题,用户体验不好,解决办法就是尽量别用定位,实在要用就用absolute。
2、如果你用的rem布局,可能会在红米、三星note4等手机上出现页面排版混乱的问题,所以rem慎用,移动端布局可以用flex,如果非要用rem的话就只能一点一点调整你的根元素大小,利用navigator.userAgent可以获取手机型号,单独给不兼容的手机提供一个font-size。
3、同样的还是rem布局,如果你项目里的border用的是rem单位,在有些安卓手机上是不会显示出来的,直接用px为单位就好了。
4、line-height属性在在安卓手机显示有误,比如一行文本想垂直居中,最简单的办法就是把line-height设置为文本所在标签的高度,但是在安卓手机上会有问题,解决办法就是为安卓手机单独设置line-height。我的项目里本来标准的line-height是0.5rem,但是在安卓上我设了0.35rem,网上有很多解决办法,但是都不怎么靠谱。
5、如果你有需求是用户在文本框输入完然后按回车就可以搜索的话,会碰到一个问题,就是键盘上的搜索键,可能显示的不是‘搜索’这两个字,像苹果显示的就是‘下一项‘,有的显示的是‘换行’,这样体验也不是很好,有些人肯定输入完以后没看到搜索按钮会懵逼,所以把键盘的enter键的字改成搜索是有必要的,解决办法:把该文本框用form标签包起来就可以了。
6、移动端如果要用c3动画的话必须要加前缀,-webkit-,否则在安卓手机上动画会失效,iOS当然是没问题的。
7、click事件,都知道在移动端会有300毫秒的延迟,移动端最好用touch事件,别用click事件,但是像我这种人click用习惯了,而且如果是在手机浏览器里打开的话click事件也能正常执行,看不出来延迟效果,至少我没看出来,所以可以直接用click,但是如果要在App里打开的话,click事件的延迟十分明显,解决办法除了把click事件全部改为touch事件外还有一种解决办法,利用fastclick插件,可以清除click事件的300毫秒延迟。
8、在移动端做搜索的时候往往会用到keyup或者keydown事件,但是在iOS会出现兼容问题,iOS自带的键盘有一部分是不触发键盘事件的,如下图,我输入了zhang,键盘上部有一排待选的字,这部分是不触发键盘事件的,所以说如果我选了个“张”字,是不会触发搜索的,我觉得这算个bug吧,在第三方输入法上不会存在这种bug,但iOS用自带键盘的用户也很多,所以还是得解决,解决办法就是将键盘事件换input propertychange事件就可以了,例:把$('.search').keyup(function(){})换成$('.search').on('input propertychange',function(){}),此方法是js原生的方法,就是oninput,类似于onclick,可以实时监听文本框的内容。(此bug在手机浏览器和App里均会出现)。
写之前感觉可以扯很多,确实也碰到了不少问题,但真正写起来暂时就好像也没多少,临时决定写的,所以很多一下想不起来,以上算是比较常见的兼容问题了,今后还会再更新的。
本文来自:湖南第一李青(LeeSin),不能说湖南第一,那样显得太狂了,湖南最强吧。