移动端H5开发常用技巧

html 篇

常用的meta属性设置

meta对于移动端的一些特殊属性,可根据需要自行设置

//Android 禁止屏幕旋转

//全屏显示

//UC应用模式,使用了application这种应用模式后,页面讲默认全屏,禁止长按菜单,禁止收拾,标准排版,以及强制图片显示。

//QQ强制竖屏

//QQ强制全屏

//QQ应用模式

电话号码识别

在 iOS Safari (其他浏览器和 Android 均不会)上会对那些看起来像是电话号码的数字处理为电话链接,比如:

7 位数字,形如:1234567

带括号及加号的数字,形如:(+86)123456789

双连接线的数字,形如:00-00-00111

11 位数字,形如:13800138000

关闭识别

开启识别

123456

邮箱识别(Android)

安卓上会对符合邮箱格式的字符串进行识别,我们可以通过如下的 meta 来管别邮箱的自动识别:

同样地,我们也可以通过标签属性来开启长按邮箱地址弹出邮件发送的功能:

dooyoe@gmail.com

css 篇

0.5px细线

移动端 H5 项目越来越多,设计师对于 UI 的要求也越来越高,比如 1px 的边框。在高清屏下,移动端的 1px 会很粗。

那么为什么会产生这个问题呢?主要是跟一个东西有关,DPR(devicePixelRatio) 设备像素比,它是默认缩放为 100%的情况下,设备像素和 CSS 像素的比值。目前主流的屏幕 DPR=2(iPhone 8),或者 3(iPhone 8 Plus)。拿 2 倍屏来说,设备的物理像素要实现 1 像素,而 DPR=2,所以 css 像素只能是 0.5。

下面介绍最常用的方法

/* 底边框 */

.b-border{

position: relative;

}

.b-border:before{

content:'';

position: absolute;

left:0;

bottom:0;

width:100%;

height:1px;

background:#d9d9d9;

-webkit-transform:scaleY(0.5);

transform:scaleY(0.5);

-webkit-transform-origin:00;

transform-origin:00;

}

/* 上边框 */

.t-border{

position: relative;

}

.t-border:before{

content:'';

position: absolute;

left:0;

top:0;

width:100%;

height:1px;

background:#d9d9d9;

-webkit-transform:scaleY(0.5);

transform:scaleY(0.5);

-webkit-transform-origin:00;

transform-origin:00;

}

/* 右边框 */

.r-border{

position: relative;

}

.r-border:before{

content:'';

position: absolute;

right:0;

bottom:0;

width:1px;

height:100%;

background:#d9d9d9;

-webkit-transform:scaleX(0.5);

transform:scaleX(0.5);

-webkit-transform-origin:00;

transform-origin:00;

}

/* 左边框 */

.l-border{

position: relative;

}

.l-border:before{

content:'';

position: absolute;

left:0;

bottom:0;

width:1px;

height:100%;

background:#d9d9d9;

-webkit-transform:scaleX(0.5);

transform:scaleX(0.5);

-webkit-transform-origin:00;

transform-origin:00;

}

/* 四条边 */

.setBorderAll{

position: relative;

&:after {

content:' ';

position: absolute;

top:0;

left:0;

width:200%;

height:200%;

transform:scale(0.5);

transform-origin: left top;

box-sizing: border-box;

border:1pxsolid#e5e5e5;

border-radius:4px;

}

}

屏蔽用户选择

禁止用户选择页面中的文字或者图片

div{

-webkit-touch-callout: none;

-webkit-user-select: none;

-khtml-user-select: none;

-moz-user-select: none;

-ms-user-select: none;

user-select: none;

}

清除输入框内阴影

在 iOS 上,输入框默认有内部阴影,以这样关闭:

div{

-webkit-appearance: none;

}

如何禁止保存或拷贝图像

代码如下

img{

-webkit-touch-callout: none;

}

输入框默认字体颜色

设置 input 里面 placeholder 字体的颜色

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;

}

用户设置字号放大或者缩小导致页面布局错误

设置字体禁止缩放

body{

-webkit-text-size-adjust:100%!important;

text-size-adjust:100%!important;

-moz-text-size-adjust:100%!important;

}

android系统中元素被点击时产生边框

部分android系统点击一个链接,会出现一个边框或者半透明灰色遮罩, 不同生产商定义出来额效果不一样。去除代码如下

a,button,input,textarea{

-webkit-tap-highlight-color:rgba(0,0,0,0)

-webkit-user-modify:read-write-plaintext-only;

}

iOS 滑动不流畅

ios 手机上下滑动页面会产生卡顿,手指离开页面,页面立即停止运动。整体表现就是滑动不流畅,没有滑动惯性。iOS 5.0 以及之后的版本,滑动有定义有两个值 auto 和 touch,默认值为 auto。

「解决方案」

在滚动容器上增加滚动 touch 方法

.wrapper{

-webkit-overflow-scrolling: touch;

}

设置 overflow 设置外部 overflow 为 hidden,设置内容元素 overflow 为 auto。内部元素超出 body 即产生滚动,超出的部分 body 隐藏。

body{

overflow-y: hidden;

}

.wrapper{

overflow-y: auto;

}

js 篇

移动端click屏幕产生200-300 ms的延迟响应

移动设备上的web网页是有300ms延迟的,往往会造成按钮点击延迟甚至是点击失效。解决方案:

fastclick可以解决在手机上点击事件的300ms延迟

zepto的touch模块,tap事件也是为了解决在click的延迟问题

触摸事件的响应顺序

ontouchstart

ontouchmove

ontouchend

onclick

audio 和 video 在 ios 和 andriod 中自动播放

这个不是bug,由于自动播放网页中的音频或视频,会给用户带来一些困扰或者不必要的流量消耗,所以苹果系统和安卓系统通常都会禁止自动播放和使用 JS 的触发播放,必须由用户来触发才可以播放。加入自动触发播放的代码

$('html').one('touchstart',function(){

audio.play()

})

iOS 上拉边界下拉出现空白

手指按住屏幕下拉,屏幕顶部会多出一块白色区域。手指按住屏幕上拉,底部多出一块白色区域。

在 iOS 中,手指按住屏幕上下拖动,会触发 touchmove 事件。这个事件触发的对象是整个 webview 容器,容器自然会被拖动,剩下的部分会成空白。

「解决方案」

document.body.addEventListener(

'touchmove',

function(e){

if(e._isScroller)return

// 阻止默认事件

e.preventDefault()

},

{

passive:false

}

)

ios 日期转换 NAN 的问题

将日期字符串的格式符号替换成'/'

'yyyy-MM-dd'.replace(/-/g,'/')

软键盘问题

IOS 键盘弹起挡住原来的视图

可以通过监听移动端软键盘弹起 Element.scrollIntoViewIfNeeded(Boolean)方法用来将不在浏览器窗口的可见区域内的元素滚动到浏览器窗口的可见区域。如果该元素已经在浏览器窗口的可见区域内,则不会发生滚动。

true,则元素将在其所在滚动区的可视区域中居中对齐。

false,则元素将与其所在滚动区的可视区域最近的边缘对齐。根据可见区域最靠近元素的哪个边缘,元素的顶部将与可见区域的顶部边缘对准,或者元素的底部边缘将与可见区域的底部边缘对准。

window.addEventListener('resize',function(){

if(

document.activeElement.tagName ==='INPUT'||

document.activeElement.tagName ==='TEXTAREA'

) {

window.setTimeout(function(){

if('scrollIntoView'indocument.activeElement) {

document.activeElement.scrollIntoView(false)

}else{

document.activeElement.scrollIntoViewIfNeeded(false)

}

},0)

}

})

onkeyUp 和 onKeydown 兼容性问题

IOS 中 input 键盘事件 keyup、keydown、等支持不是很好, 用 input 监听键盘 keyup 事件,在安卓手机浏览器中没有问题,但是在 ios 手机浏览器中用输入法输入之后,并未立刻相应 keyup 事件

IOS12 输入框难以点击获取焦点,弹不出软键盘

定位找到问题是 fastclick.js 对 IOS12 的兼容性,可在 fastclick.js 源码或者 main.js 做以下修改

FastClick.prototype.focus =function(targetElement){

varlength

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()

}

}

IOS 键盘收起时页面没用回落,底部会留白

通过监听键盘回落时间滚动到原来的位置

window.addEventListener('focusout',function(){

window.scrollTo(0,0)

})

//input输入框弹起软键盘的解决方案。

varbfscrolltop =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);

})

IOS 下 fixed 失效的原因

软键盘唤起后,页面的 fixed 元素将失效,变成了 absolute,所以当页面超过一屏且滚动时,失效的 fixed 元素就会跟随滚动了。不仅限于 type=text 的输入框,凡是软键盘(比如时间日期选择、select 选择等等)被唤起,都会遇到同样地问题。

解决方法: 不让页面滚动,而是让主体部分自己滚动,主体部分高度设为 100%,overflow:scroll

.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%;

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,794评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,050评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,587评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,861评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,901评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,898评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,832评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,617评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,077评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,349评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,483评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,199评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,824评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,442评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,632评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,474评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,393评论 2 352

推荐阅读更多精彩内容