移动web开发的特点

  1. 运行在手机端web页面(H5页面): 对于手机而言,兼容HTML5所有的新特性
  2. 跨平台性:可以运行在PC端、IOS端 、安卓端,
  3. 基于webview:webView是移动端提供的运行JavaScript的环境,是系统渲染Web网页的一个控件,可与页面JavaScript交互,实现混合开发,其中Android和 IOS又有些不同:
  4. 告别 IE 拥抱webkit:对于日常的PC开发来说,需要兼容各种各样厂商的浏览器,但是对于移动web,基本就告别了浏览器厂商的兼容性,因为移动端手机webview基本上都是基于webkit内核。
  5. 更高的适配性和性能要求:程序运行在手机端,但手机屏幕尺寸各式各样,性能方面跟PC相比要相对差一点,网络状况也是错综复杂。

Rem 布局适配原理

rem 是(font size of the root element),就是一个字体单位,根据 html 根元素的字体大小,实时变化 。 浏览器 默认字体大小是 16px 。

  • 字体单位:值根据 html 根元素字体大小而定,同样可以作为宽度,高度等单位
  • 适配原理:将 px 替换成 rem ,动态修改 html 的font-size适配
  • 兼容性:IOS6.1+ 和Android2.1+,基本覆盖所有流行的手机系统

rem 基准值及数值计算

基准值: html 根元素字体大小的值,默认font-size: 16px,适配需要根据屏幕尺寸动态修改html font-size,方式:Media Query(媒体查询) 和 JS 动态获取

数值计算:px 值经换算得到的 rem 值 ,如1rem = 16px ,10rem = 160px

750的设计稿,宽高240px, 字体大小24px , 使用以下方式实现适配

Media Query(媒体查询)

在一些相对简单的页面,可以使用定高宽度百分比的布局,而使用Media Query(媒体查询)和Flex布局,也基本上能够达到实现响应式布局的要求。

但是移动端屏幕尺寸太多了,针对每一个尺寸都写一套media 不太现实,写css样式时也不应该依赖css的顺序,后一个覆盖前一个,这样不利于维护和代码的可读性。

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0,user-scalable=no">
<title>Rem</title>
<style type="text/css">
.box {
width: 10rem;
height: 10rem;
background-color: blue;
font-size:1rem;
color: #fff;
} @media screen and (max-width:376px) and (min-width:321px) {
html {
font-size: 24px;
}
}
@media screen and (max-width:320px) {
html {
font-size: 20px;
}
}
</style>
</head> <body>
<div class="box">
hello rem
</div>
</body>
</html>

scss 工程使用函数计算

rem:37.5px 就是页面的基准值,写样式时须以一个确定的屏幕来作为参考(视觉稿), 假如视觉稿是以 iphone6 的屏幕为基准设计的,iPhone6 的屏幕大小是 375px,

@function px2rem($px){
$rem : 37.5px;
@return ($px/$rem) + rem;
} /* 使用 */
.box {
width: px2rem(240px);
height: px2rem(240px);
background-color: blue;
font-size:px2rem(24px);
color: #fff;
}

JS动态获取屏幕的宽度

以一个确定的屏幕来作为参考(视觉稿),再通过JS动态获取屏幕的宽度,设置rem基准值:

  <style type="text/css">
.box {
width: 5rem; // 以一个确定的屏幕来作为参考(视觉稿) 1rem = 37.5px
height: 5rem;
background-color: blue;
font-size:1rem;
color: #fff;
}
</style> <body>
<div class="box">
hello rem
</div>
</body>
<script>
// 获取视窗宽度
let htmlWidth = document.documentElement.clientWidth || document.body.clientWidth
console.log(htmlWidth); let htmlDom = document.getElementsByTagName('html')[0]
htmlDom.style.fontSize = htmlWidth/10 + 'px' // 监听页面 缩放事件
window.addEventListener('resize',function(){
let htmlWidth = document.documentElement.clientWidth || document.body.clientWidth
htmlDom.style.fontSize = htmlWidth/10 + 'px' // iP6, 375 / 10 = 37.5
}) </script>

直接将html 的 font-size 设置成 100px

一般情况,根据px值 计算rem值较为繁琐,还可以将 html 的 font-size 设置成 100px,直接将数值除以 100 在加上 rem 。

  <style type="text/css">
.box {
width: 2.4rem; // 以一个确定的屏幕来作为参考(视觉稿) 1rem = 37.5px
height: 2.4rem;
background-color: blue;
font-size:0.24rem;
color: #fff;
}
html{
font-size:100px;
}
</style> <body>
<div class="box">
hello rem
</div>
</body>

移动web开发适配秘籍Rem的更多相关文章

  1. 移动web开发适配方案之Rem

    移动端为什么要做适配 移动端相对PC端来说大部分浏览器内核都是基于Webkit的,所以大部分都支持CSS3的最新语法.但是由于手机的屏幕尺寸和分辨率都不太一样(尤其是安卓),所以不得不对不同分辨率的手 ...

  2. 移动 WEB 开发布局方式 ---- rem 适配布局

    一.rem 基础 1. rem 单位 em : 相对于父元素的字体大小来说的 <div> <p></p> </div> div { font-size: ...

  3. 移动web开发适配rem

    移动的meta标签 <meta  name="viewport" content="width=device-width, initial-scale=1,user ...

  4. web app变革之rem(手机屏幕实现全适配)

    以往web移动适配,常规写法是:media only screen @media only screen and (min-device-width: 320px){ //针对iPhone 3 } @ ...

  5. 移动端页面开发适配 rem布局原理

    主题 HTML移动端页面开发适配 rem布局原理 什么是适配,为什么要适配 我们拿到的设计图一般是以640,750,1080分辨率为基准设计的,而现在的手机终端各式各样,分辨率不同,逻辑像素不同 ,适 ...

  6. 移动web适配利器-rem

    移动web适配利器-rem 前言 提到rem,大家首先会想到的是em,px,pt这类的词语,大多数人眼中这些单位是用于设置字体的大小的,没错这的确是用来设置字体大小的,但是对于rem来说它可以用来做移 ...

  7. 移动端适配(rem & viewport)--移动端开发整理笔记(四)

    移动端适配 通过rem适配 em: 根据元素自身的字体大小来计算自己的尺寸 rem: (root em) 根据根节点(html)的字体大小来计算自己的尺寸   我们知道,在不同的手机设备,分辨率大小是 ...

  8. 转载:移动web开发规范

    本文来源:http://blog.csdn.net/joueu/article/details/44329825 以下是规范建议,均是日常在开发当中的的一些经验,仅供参考. 移动web开发规范 一.头 ...

  9. 移动Web开发小技巧

    移动Web开发小技巧 添加到主屏后的标题(IOS) name="apple-mobile-web-app-title" content="标题"> 启用  ...

  10. 超好:web app变革之rem

    感谢你的阅读,本文由 腾讯ISUX 版权所有,转载时请注明出处,违者必究,谢谢你的合作.注明出处格式:腾讯ISUX (https://isux.tencent.com/web-app-rem.html ...

随机推荐

  1. java学习之旅(day.03)

    整数拓展: 进制 二进制:以0b开头 十进制:我们生活中的正常数 int i=10 八进制:以0开头 int i=010 十六进制:以0x开头 0~9 A~F int i=0x10 浮点数拓展: fl ...

  2. 解决“在windows里的记事本里编辑的汉字文本文件,上传到linux服务器上出现乱码“问题

    目录 一.前期准备 二.编码转换 一.前期准备 1.首先在windows环境下打开记事本,然后创建一个包含汉字和英文的文本文件,输入内容"测试在windows里的记事本里编辑的文本文 件,上 ...

  3. WordPress网站被黑怎么办?【含解决方案】

    在我们的日常WordPress主题售后工作中,经常会有用户反馈网站出现问题,例如:阿里云提示后门木马文件:打开后跳转到其他地址:页面出现乱码:被添加了其他内容等,根据我们的经验,这种一般都是网站被黑导 ...

  4. java 反射——任意类型数组扩容

    //java object[]无法转换为原对象类型,可以使用反射来做. //这里的参数不是传object[] 而是传object. public Object GoodArrayGrow(Object ...

  5. Vue 3指令与事件处理

    title: Vue 3指令与事件处理 date: 2024/5/25 18:53:37 updated: 2024/5/25 18:53:37 categories: 前端开发 tags: Vue3 ...

  6. WPS相关技巧

    1 标题自动编号 首先,新建一个空白word,打开.点击默认的标题样式,可以看到并不会自动编号. 接下来,就设置如何自动编号.首先选择"编号". 然后,选择"多级编号&q ...

  7. Qt初始化代码基本说明

    参考视频:黑马程序员https://www.bilibili.com/video/BV1XW411x7NU?p=4 1  工程基本介绍 按照这个基本步骤(https://www.cnblogs.com ...

  8. Python3基本语法(新)

    目录 基本语法 输出print() 格式化输出 标识符 import关键字 保留字(关键字) 注释 多行注释 1.单引号(''') 2.双引号(""") 缩进 空行 同一 ...

  9. 前端传参中文需要utf-8转一下给后端

    const Msg = this.form.Msg.replace( (/%(u[0-9A-F]{4})|(%[0-9A-F]{2})/gm, $0 => { return escape($0) ...

  10. Nodejs中间件 中间件分类和自定义中间件

    中间件 中间件理解 中间件可以理解为业务流程的中间处理环节.如生活中吃一般炒青菜,大约分为如下几步骤 express中当一个请求到达的服务器之后,可以在给客户响应之前连续调用多个中间件,来对本次请求和 ...