H5移动端知识点总结

闲来无事,想学学H5方面的知识,之前学过基础,现在想认真着手下,网上找了些大牛的总结,我也就搬过来,方便查阅。

一、meta标签

1、控制显示区域各种属性:
<meta content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0" name="viewport">
width:viewport的宽度
height:viewport的高度
initial-scale:初始的缩放比例
minimum-scale:允许用户缩放到的最小比例

maximum-scale:允许用户缩放到的最大比例

user-scalable:用户是否可以手动缩放
2、IOS中Safari允许全屏浏览:
<meta content="yes" name="apple-mobile-web-app-capable">
3、IOS中Safari顶端状态条样式:
<meta content="black" name="apple-mobile-web-app-status-bar-style">
4、IOS中Safari设置保存到桌面图标
需要在网站的根目录下存放favicon图标,防止404请求(使用fiddler可以监听到)
<link rel="apple-touch-icon" href="icon.png">

5、忽略将页面中的数字识别为电话号码

一般情况下,IOS和Android系统都会默认某长度内的数字为电话号码

二、取消表单元素在点击态时的边框以及半透明灰色背景

input, textarea, button, a{ 
  -webkit-tap-highlight-color:rgba(0,0,0,0); 
}


三、移除原生控件样式

input,button,textarea {
    -webkit-appearance: none;
}


四、使用rem来做响应式开发
针对不同的设备,对页面rem做不同缩放

html {
  font-size: $baseFontSize;
  @media screen and (min-width: 320px) {
    font-size: $baseFontSize*.9;
  }
  @media screen and (min-width: 360px) {
    font-size: $baseFontSize;
  }
  @media screen and (min-width: 400px) {
    font-size: $baseFontSize*1.1;
  }
}


五、定义字体
如无特殊需求,手机端无需定义中文字体,使用系统默认;
英文字体和数字字体可使用 Helvetica ,三种系统(ios、android、winphone)都支持。

<pre name="code" class="css">body{
    font-family: Helvetica;
}

 

六、flex布局兼容性写法
使用 Sass mixin实现flex布局

@mixin display-flex() {
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
}


// 参数:数字,默认:1
@mixin flex($value: 1) {
  -webkit-box-flex: $value;
  -webkit-flex: $value;
  flex: $value;
}


// 参数:数字,默认:1
@mixin order($value: 1) {
  -webkit-box-ordinal-group: $value;
  -webkit-order: $value;
  order: $value;
}


// 参数:row, row-reverse, column, column-reverse
@mixin flex-direction($direction) {
  @if ($direction == row) {
    -webkit-box-direction: normal;
    -webkit-box-orient: horizontal;
    -webkit-flex-direction: row;
    flex-direction: row;
  } @else if ($direction == row-reverse) {
    -webkit-box-pack: end;
    -webkit-box-direction: reverse;
    -webkit-box-orient: horizontal;
    -webkit-flex-direction: row-reverse;
    flex-direction: row-reverse;
  } @else if ($direction == column) {
    -webkit-box-direction: normal;
    -webkit-box-orient: vertical;
    -webkit-flex-direction: column;
    flex-direction: column;
  } @else if ($direction == column-reverse) {
    -webkit-box-pack: end;
    -webkit-box-direction: reverse;
    -webkit-box-orient: vertical;
    -webkit-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
}


//  参数:flex-start, center, flex-end, space-between
@mixin justify-content($value) {
  @if ($value == flex-start) {
    -webkit-box-pack: start;
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
  } @else if ($value == center) {
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    justify-content: center;
  } @else if ($value == flex-end) {
    -webkit-box-pack: end;
    -webkit-justify-content: flex-end;
    justify-content: flex-end;
  } @else if ($value == space-between) {
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
  }
}


//  参数:flex-start, center, flex-end, baseline, stretch
@mixin align-items($value) {
  @if ($value == flex-start) {
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
    align-items: flex-start;
  } @else if ($value == center) {
    -webkit-box-align: center;
    -webkit-align-items: center;
    align-items: center;
  } @else if ($value == flex-end) {
    -webkit-box-align: end;
    -webkit-align-items: flex-end;
    align-items: flex-end;
  } @else if ($value == baseline) {
    -webkit-box-align: baseline;
    -webkit-align-items: baseline;
    align-items: baseline;
  } @else if ($value == stretch) {
    -webkit-box-align: stretch;
    -webkit-align-items: stretch;
    align-items: stretch;
  }
}


七、移动端touch事件

当用户手指放在移动设备在屏幕上滑动会触发的touch事件
touchstart:当手指触碰屏幕时候发生。不管当前有多少只手指
touchmove:当手指在屏幕上滑动时连续触发。通常我们再滑屏页面,会调用event的preventDefault()可以阻止默认情况的发生:阻止页面滚动
touchend:当手指离开屏幕时触发
touchcancel:系统停止跟踪触摸时候会触发。例如在触摸过程中突然页面alert()一个提示框,此时会触发该事件,这个事件比较少用

八、click产生200-300 ms的延迟响应
页面js捕获click事件的回调函数处理,需要300ms后才生效
解决方案:
1、fastclick可以解决在手机上点击事件的300ms延迟
2、zepto的touch模块,tap事件也是为了解决在click的延迟问题

九、按钮active态
在iOS系统的移动设备中,需要在按钮元素或body/html上绑定一个touchstart事件才能激活:active状态

document.body.addEventListener('touchstart', function () { 
    //...空函数即可
});  


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值