移动web-day05-移动适配

今日重点: 移动适配

rem: 目前多数企业在用的解决方案
vw / vh:未来的解决方案

1.rem

能够使用rem单位设置网页元素的尺寸
思考 :
Ø手机屏幕大小不同,分辨率不同, 如何设置不同的HTML标签字号?
Ø设备宽度不同,HTML标签字号设置多少合适?
Ø设备宽度大, 元素尺寸大
Ø设备宽度小,元素尺寸小


目前rem布局方案中,将网页等分成10份, HTML标签的字号为视口宽度的 1/10

网页效果
Ø屏幕宽度不同,网页元素尺寸不同(等比缩放)

px单位或百分比布局可以实现吗?
Ø px单位是绝对单位
Ø百分比布局特点宽度自适应,高度固定

rem单位
Ø 相对单位
Ø rem单位是相对于HTML标签的字号计算结果
Ø 1rem = 1HTML字号大小

2. rem移动适配

能够使用媒体查询设置差异化CSS样式
思考 :
Ø手机屏幕大小不同,分辨率不同, 如何设置不同的HTML标签字号?

Ø媒体查询
媒体查询能够检测视口的宽度,然后编写差异化的 CSS 样式
当某个条件成立, 执行对应的CSS样式

写法 :

示意图

3. rem适配原理

实现在不同宽度的设备中,网页元素尺寸等比缩放效果
rem单位尺寸

  1. 根据视口宽度,设置不同的HTML标签字号

  2. 书写代码,尺寸是rem单位
    确定设计稿对应的设备的HTML标签字号
    查看设计稿宽度 → 确定参考设备宽度(视口宽度) → 确定基准根字号(1/10视口宽度)

    rem单位的尺寸
    Ø N * 37.5 = 68 → N = 68 / 37.5
    Ø rem单位的尺寸 =** px单位数值 / 基准根字号**

4. flexible

使用flexible js配合rem实现在不同宽度的设备中,网页元素尺寸等比缩放效果

思考:
咱们检测了3个视口,分别设置了根字号,有什么弊端吗?
答:手机设备多,屏幕尺寸不一,视口不仅仅有这3个


➢ flexible.js是手淘开发出的一个用来适配移动端的js框架
➢ 核心原理就是根据不同的视口宽度给网页中html根节点设置不同的font-size

1. Less

使用Less运算写法完成px单位到rem单位的转换
思考:
在px单位转换到rem单位过程中,哪项工作是最麻烦的?
答:除法运算。CSS不支持计算写法。
解决方案:可以通过Less实现。

使用Less语法快速编译生成CSS代码
Less是一个CSS预处理器, Less文件后缀是.less
扩充了 CSS 语言, 使 CSS 具备一定的逻辑性、计算能力
注意:浏览器不识别Less代码,目前阶段,网页要引入对应的CSS文件


Easy Less :
vscode插件
作用:less文件保存自动生成css文件

注释:
单行注释
Ø语法:// 注释内容
Ø快捷键:ctrl + /

块注释
Ø语法:/ 注释内容 /
Ø快捷键: shift + alt + A
使用Less运算写法完成px单位到rem单位的转换

运算:
加、减、乘直接书写计算表达式
除法需要添加 小括号 或 .
注意:
Ø 表达式存在多个单位以第一个单位为准


能够使用Less嵌套写法生成后代选择器

嵌套:
作用:快速生成后代选择器。

语法:


注意:&不生成后代选择器,表示当前选择器,通常配合伪类或伪元素使用


变量 — — — —
思考:
Ø网页中, 文字文字颜色基本都是统一的, 如果网站改版,变换文字颜色, 如何修改代码?
Ø方法一:逐一修改属性值(太繁琐)

.box { color:pink }        a { color:pink }       p { color:pink }

Ø方法二: 把颜色提前存储到一个容器,设置属性值为这个容器名

**变量:存储数据,方便使用和修改**

语法:
定义变量:@变量名: 值;
使用变量:CSS属性:@变量名;

// 1. 定义
@fontColor:pink;
// 2. 使用
.box { color:@fontColor }
.a { color:@fontColor }

能够使用Less导入写法引用其他Less文件
思考:
Ø 开发网站时,网页如何引入公共样式?
ØCSS:书写link标签
ØLess:导入
导入: @import “文件路径”;


使用Less语法导出CSS文件

方法一:
Ø 配置EasyLess插件, 实现所有Less有相同的导出路径
配置插件: 设置 → 搜索EasyLess → 在setting.json中编辑 → 添加代码(注意,必须是双引号


方法二:
控制当前Less文件导出路径
Ø Less文件第一行添加如下代码, 注意文件夹名称后面添加 /

1  // out: ./css/
1  // out: ./css/common.css

禁止导出 : **
Ø 在less文件
第一行添加: // out: false**

1  //out:false

实战演练

准备工作:项目目录及文件
根目录(paradise / FC)


目标:实现在不同宽度设备中等比缩放的网页效果
整体布局:网页为灰色背景色

主体内容
Ø 底部间距(高度与工具栏相同)

底部工具栏
Ø固定定位
Ø尺寸
Ø背景色


注意:需要设置基准根字号 @rootSize: 37.5;

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

推荐阅读更多精彩内容