移动适配

rem:目前多数企业在用的解决方案

rem:(能够使用rem单位设置网页元素的尺寸)

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

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

适配方案  rem  vw / vh
rem单位  相对单位  rem单位是相对于HTML标签的字号计算结果  1rem = 1HTML字号大小
思考: 1. 手机屏幕大小不同,分辨率不同, 如何设置不同的HTML标签字号?媒体查询  2. 设备宽度不同,HTML标签字号设置多少合适?
媒体查询能够检测视口的宽度,然后编写差异化的 CSS 样式
当某个条件成立, 执行对应的CSS样式
rem移动适配 -媒体查询:  能够使用媒体查询设置差异化CSS样式

写法:  @media (媒体特性) {        @media (width:320px) {

        选择器 {               html {

          CSS属性             font-size: 32px;  

        }                }

      }                  }

设备宽度不同,HTML标签字号设置多少合适?  设备宽度大, 元素尺寸大  设备宽度小,元素尺寸小
目前rem布局方案中,将网页等分成10份,HTML标签的字号为视口宽度的1/10
 

rem适配原理:(实现在不同宽度的设备中,网页元素尺寸等比缩放效果)

思考:工作中,书写代码的尺寸要参考设计稿尺寸,设计稿中是px还是rem?  px

如何确定rem的数值? 

计算68px是多少个rem?(假定设计稿适配375px视口)  N * 37.5 = 68 ——> N = 68 / 37.5

rem单位尺寸  

1.确定设计稿对应的设备的HTML标签字号  

确定设计稿对应的设备的HTML标签字号  查看设计稿宽度 → 确定参考设备宽度(视口宽度) → 确定基准根字号(1/10视口宽度)

2.rem单位的尺寸 

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

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

 flexible.js是手淘开发出的一个用来适配移动端的js框架。
 核心原理就是根据不同的视口宽度给网页中html根节点设置不同的font-size。
Less语法:(使用Less语法快速编译生成CSS代码)
Less是一个CSS预处理器, Less文件后缀是.less
 扩充了 CSS 语言, 使 CSS 具备一定的逻辑性、计算能力。
 注意:浏览器不识别Less代码,目前阶段,网页要引入对应的CSS文件。
注释:单行注释:语法:// 注释内容  快捷键:Ctrl+/  多行注释(块注释):语法:/* 注释内容 */  快捷键:Shift+alt+A
Less语法:(使用Less运算写法完成px单位到rem单位的转换)(能够使用Less嵌套写法生成后代选择器)
运算:加、减、乘直接书写计算表达式  除法需要添加小括号 或 . 
注意:表达式存在多个单位以第一个单位为准
嵌套:思考:书写CSS选择器时, 如何避免样式冲突?
嵌套: 作用:快速生成后代选择器。
注意:&不生成后代选择器,表示当前选择器,通常配合伪类或伪元素使用
变量:方法二:把颜色提前存储到一个容器,设置属性值为这个容器名
变量:为了存储数据,方便使用和修改
语法L定义变量:@变量名: 值;  使用变量:CSS属性: @变量名;
Less语法:(能够使用Less导入写法引入其他Less文件)
思考:开发网站时,网页如何引入公共样式?  CSS: 书写link标签  Less:导入
导入:@import "文件路径";  
@import './01-体验less.less';
@import './02-注释';
如果是less文件, 可以省略后缀.less
使用Less语法导出CSS文件
方法一: 配置EasyLess插件, 实现所有Less有相同的导出路径
配置插件: 设置 → 搜索EasyLess → 在setting.json中编辑 → 添加代码(注意,必须是双引号)
方法二:控制当前Less文件导出路径   Less文件第一行添加如下代码, 注意文件夹名称后面添加 /
// out: ./css/
//out: ./css/common.css
思考:所有的Less文件都需要导出CSS文件吗?  禁止导出: 在less文件第一行添加:   // out: false

vw/vh:未来的解决方案

随机推荐

  1. git cherry-pick 同步修改到另一个分支

    我们在开发中有时会遇到,需要将另一个分支部分修改同步到当前分支. 如下图,想把 devA 分支中 commit E 和 F,同步到下面绿色的 devB 分支中. 这时候就可以使用 git cherry ...

  2. PowerDotNet平台化软件架构设计与实现系列(15):支付平台

    PowerDotNet个人项目中功能全面而强大的一个系统是支付平台.我对PowerDotNet的自信很大程度上来自于经过PowerDotNet重写后的支付.财务.结算.CRM等业务型公共服务系统的稳定 ...

  3. 2、postman调试

    Postman接口调试: postman博客参考 Postman是一个API(接口)开发协作平台,其提供了发送请求.检查响应.自动化测试.数据模拟.服务监控.文档分享等一系列与API(接口)开发有关的 ...

  4. 2022年7月13日,第四组,周鹏,JS做计算器代码

    代码不难,看了我前面笔记的应该能看懂. 没看?(= ̄ω ̄=)喵了个咪(๑‾᷅^‾᷅๑) 嫌弃你 还看啥,去看啊!要不直接复制代码吧!( ̄へ ̄)( ̄へ ̄)( ̄へ ̄) Document 0 / * - 7 ...

  5. .Net引用根目录子文件夹下的dll文件

    在.Net开发的时候,有时候会引用一套库,这些库是由多个dll文件.正常情况下,这些dll文件需要拷贝到运行根目录下.如果这些dll文件比较多,加上其他直接引用的dll,这样会导致根目录下非常乱.我们 ...

  6. 题解P1559 运动员最佳匹配问题

    简要题意 给出 \(n\) 个白色顶点,\(n\) 个黑色顶点.白色顶点 \(i\) 和黑色顶点 \(j\) 之间的边的权为 \(P_{i,j}\cdot Q_{j,i}\),求二分图最大权匹配. 思 ...

  7. XCTF-web新手区

    前言 刷题平台:攻防世界 web简介 WEB是CTF竞赛的主要题型,题目涉及到许多常见的WEB漏洞,诸如XSS.文件包含.代码执行.上传漏洞.SQL注入.还有一些简单的关于网络基础知识的考察,例如返回 ...

  8. python实现简单信息收集

    python实现简单信息收集 import whois import socket import sys def Query(domain): ip = socket.gethostbyname(st ...

  9. Xcode找不到.h或者.m文件解决办法 .h file not found

    Xcode找不到.h或者.m文件解决办法   .h file not found 开篇唠叨 小黑最经又开始干iOS接入微信SDK了,目前刚开始就遇到了困难,于是总结一下分享给大家,要是大家看完了还解决 ...

  10. nginx 隐藏 index.php 直接访问

    项目配置文件vhosts加上: if ( !-e $request_filename) { rewrite ^/(.*)$ /index.php/$1 last; break; } 修改后如图