1. new Date()在IOS上出现值为NAN的问题
我们常用new Date()去获取时间戳,例如
new Date("2017-08-11 12:00:00");
但在IOS下,这是使用获取到的值是NAN。 原因:因为IOS下的new Date()不支持"-“这个字符 解决方法:把”-“改成‘”/"就可以了。例如
new Date("2017-08-11 12:00:00".replace(/-/g, "/"));
2. Android部分机型使用height和line-height等值设置垂直居中,但会显示偏高的问题
在开发过程中,我们想让文字进行垂直居中时,往往会设置height和line-height等值来实现。这种方式在PC端看到的时候没有问题,但在真机上测试时,会发现部分Android机型会出现文字偏高的问题。 原因:貌似是有部分Android机型有自己默认的line-height,我们额外设置的line-height不起作用。 解决办法:设置line-height:normal,再通过padding去设置居中就可以了。
line-height:normal; padding:xxpx 0;
3. fixed 与 input
刚接触移动端 Web 开发的小伙伴应该都会听前辈们说过,不要再有 input 标签的页面使用 fixed 定位,因为这两者在一起的时候,总是会有奇奇怪怪的问题。在 iOS 上,当点击 input 标签获取焦点唤起软键盘的时候,fixed 定位会暂时失效,或者可以理解为变成了 absolute 定位,在含有滚动的页面,fixed 定位的节点和其他节点一起滚动。其实这个问题也很好解决,只要保证 fixed 定位的节点的父节点不可滚动,那么即使 fixed 定位失效,也不会和其他滚动节点一起滚动,影响界面。但是除此之外,还有很多问题比较难以解决,例如 Android 软键盘唤起后遮挡住 input 标签,用户没法看到自己输入的字符串,iOS 则需要在输入至少一个字符之后,才能将对应的 input 标签滚动到合适的位置,所以为了避开这些难以解决的坑,在有表单输入的页面,尽量用absolute 或者 flex 替换 fixed。
4、防止手机中网页放大和缩小。
viewport 设置不缩放
<meta name="viewport" content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=0" />
5.iphone及ipad下输入框默认内阴影
Element { -webkit-tap-highlight-color:rgba(255,255,255,0) }
6. 某些Android手机圆角失效
background-clip: padding-box;
7. 移动端300ms点击延迟
解决方案
- 设置meta标签禁止缩放 <meta name="viewport" content="user-scalable=no">
<meta name="viewport" content="initial-scale=1,maximum-scale=1"> - FastClick
FastClick 是 FT Labs 专门为解决移动端浏览器 300 毫秒点击延迟问题所开发的一个轻量级的库。FastClick的实现原理是在检测到touchend事件的时候,会通过DOM自定义事件立即出发模拟一个click事件,并把浏览器在300ms之后的click事件阻止掉。
FastClick可能导致的问题
8. 点击穿透问题
解决方案一:来得很直接github上有个fastclick可以完美解决 引入fastclick.js,因为fastclick源码不依赖其他库所以你可以在原生的js前直接加上
window.addEventListener( "load", function() { FastClick.attach( document.body ); }, false );
解决方案二:对于B元素本身存在默认click事件的情况,应及用touchend代替tap事件并阻止掉时A元素touchend的默认行为preventDefault(),从而阻止click事件的产生。
$("#aa").on("touchend", function (event) { //很多处理比如隐藏什么的 event.preventDefault(); });
9. 电话号码识别
在 iOS Safari (其他浏览器和 Android 均不会)上面会对那些看起来像是电话号码的数字处理为电话链接,比如:
- 7 位数字,形如:
- 带括号及加号的数字,形如:(+86)
- 双连接线的数字,形如:00-00-00111
- 11 位数字,形如:
关闭识别
<meta name="format-detection" content="telephone=no" />
开启识别
<a href="tel:"></a>
10. 邮箱识别
安卓上会对符合邮箱格式的字符串进行识别,我们可以通过如下的 meta 来管邮箱的自动识别:
<meta content="email=no" name="format-detection" />
同样地,我们也可以通过标签属性来开启长按邮箱地址弹出邮件发送的功能:
<a mailto:dooyoe@gmail.com">dooyoe@gmail.com</a>
11. 常用meta 标签的设置
meta对于移动端的一些特殊属性,可根据需要自行设置
<meta name="screen-orientation" content="portrait"> //Android 禁止屏幕旋转 <meta name="full-screen" content="yes"> //全屏显示 <meta name="browsermode" content="application"> //UC应用模式,使用了application这种应用模式后,页面讲默认全屏,禁止长按菜单,禁止收拾,标准排版,以及强制图片显示。 <meta name="x5-orientation" content="portrait"> //强制竖屏 <meta name="x5-fullscreen" content="true"> //强制全屏 <meta name="x5-page-mode" content="app"> //应用模式
12.清除输入框内阴影
在 iOS 上,输入框默认有内部阴影,所以这样关闭:
div { -webkit-appearance: none; }
13 .输入框默认字体颜色
input::-webkit-input-placeholder, textarea::-webkit-input-placeholder { color: #c7c7c7; } input:-moz-placeholder, textarea:-moz-placeholder { color: #c7c7c7; } input:-ms-input-placeholder, textarea:-ms-input-placeholder { color: #c7c7c7; }
14. 用户设置字号放大或者缩小导致页面布局错误
设置字体禁止缩放
body { -webkit-text-size-adjust: 100% !important; text-size-adjust: 100% !important; -moz-text-size-adjust: 100% !important; }
15. android系统中元素被点击时产生边框
部分android系统点击一个链接,会出现一个边框或者半透明灰色遮罩, 不同生产商定义出来的效果不一样。去除代码如下
a,button,input,textarea{ -webkit-tap-highlight-color: rgba(0,0,0,0) -webkit-user-modify:read-write-plaintext-only; }
16. audio 和 video 在 ios 和 andriod 中自动播放
这个不是bug,由于自动播放网页中的音频或视频,会给用户带来一些困扰或者不必要的流量消耗,所以苹果系统和安卓系统通常都会禁止自动播放和使用 JS 触发播放,必须由用户来触发才可以播放。加入自动触发播放的代码
$('html').one('touchstart', function() {
audio.play()
})
17 iOS 上拉边界下拉出现空白
手指按住屏幕下拉,屏幕顶部会多出一块白色区域。手指按住屏幕上拉,底部多出一块白色区域。
在 iOS 中,手指按住屏幕上下拖动,会触发 touchmove 事件。这个事件触发的对象是整个 webview 容器,容器自然会被拖动,剩下的部分会变成空白。
document.body.addEventListener( 'touchmove', function(e) { if (e._isScroller) return // 阻止默认事件 e.preventDefault() }, { passive: false } )
18 onkeyUp 和 onKeydown 兼容性问题
IOS 中 input 键盘事件 keyup、keydown、等支持不是很好, 用 input 监听键盘 keyup 事件,在安卓手机浏览器中没有问题,但是在 ios 手机浏览器中用输入法输入之后,并未立刻响应 keyup 事件
19 IOS12 输入框难以点击获取焦点,弹不出软键盘
定位找到问题是 fastclick.js 对 IOS12 的兼容性,可在 fastclick.js 源码或者 main.js 做以下修改
FastClick.prototype.focus = function(targetElement) { var length if ( deviceIsIOS && targetElement.setSelectionRange && targetElement.type.indexOf('date') !== 0 && targetElement.type !== 'time' && targetElement.type !== 'month' ) { length = targetElement.value.length targetElement.setSelectionRange(length, length) targetElement.focus() } else { targetElement.focus() } }
20 IOS 键盘收起时页面没用回落,底部会留白
通过监听键盘回落时间滚动到原来的位置
window.addEventListener('focusout', function() { window.scrollTo(0, 0) }) //input输入框弹起软键盘的解决方案。 var bfscrolltop = document.body.scrollTop $('input') .focus(function() { document.body.scrollTop = document.body.scrollHeight //console.log(document.body.scrollTop); }) .blur(function() { document.body.scrollTop = bfscrolltop //console.log(document.body.scrollTop); })
21 . iOS 下fixed 失效的原因
软键盘唤起后,页面的 fixed 元素即将失效,变成了 absolute,所以当页面超过一屏且滚动时,失效的 fixed 元素就会跟随滚动了。不仅限于 type=text 的输入框,凡是软键盘(比如时间日期选择、select 选择等等)被唤起,都会遇到同样的问题。解决方法: 不让页面滚动,而是让主体部分自己滚动,主体部分高度设置为 100%,overflow:scroll
<body> <div class='warper'> <div class='main'></div> <div> <div class="fix-bottom"></div> </body> .warper { position: absolute; width: 100%; left: 0; right: 0; top: 0; bottom: 0; overflow-y: scroll; -webkit-overflow-scrolling: touch; /* 解决ios滑动不流畅问题 */ } .fix-bottom { position: fixed; bottom: 0; width: 100%; }
到此这篇移动端开发遇到的坑盘点的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!
版权声明:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权、违法违规、事实不符,请将相关资料发送至xkadmin@xkablog.com进行投诉反馈,一经查实,立即处理!
转载请注明出处,原文链接:https://www.xkablog.com/ydkf/3338.html