移动Web学习05-移动端适配Less预处理器

7、移动端适配

7.1、什么是适配?

简单理解就是、同一个网页,在不同屏幕分辨率的设备下、显示还是一样的,你可以理解为、网页当中的图片,盒子之间的距离、文字的大小、随着屏幕分辨率的变化而变化

前面我们学习了flex布局的方式进行网页布局、我们发现、布局盒子可以随着不同分辨率、而进行不同的显示、

但是我们调试、我前一个阶段写的小兔鲜移动端页面、发现当分辨率变化时、字体和图片的大小、并不能随着分辨率的变化而变化

为什么?因为我们以前用的是px,他并不是一个相对单位、而是一个绝对单位,不管在什么样的屏幕下、永远都是那么大?

那么怎么做到适配?下面我们来聊下适配方案

7.2、移动端适配方案

flex + rem单位 做适配效果 (比如淘宝和小米移动端) 当前市场最多

flex + viewport width /vh单位 做适配效果 (比如 B站移动端 ) 新兴,马上的一个趋势

让flex做布局(盒子摆放),让rem或者vw/vh 实现网页元素的尺寸(宽度和高度)适配屏幕

7.3、rem 适配

px单位+百分比布局能实现适配嘛?

px单位是绝对单位

百分比布局特点宽度自适应,高度固定

rem单位

rem 是一个相对单位,1rem 就是 html文字的大小

比如

html {font-size: 35px;
}

则此时 1rem 就是 35像素。

em单位

.box{width:10emheight:10embackground-color:pinkfont-size:20px
}

上述这个盒子为200px*200px

为啥这个盒子是200*200

em单位就是当前一个字的大小,1em=20px所以.box=200px

如果此时换成rem的写法呢?

10em换成10rem,此时盒子的大小是多少?160px还是200

答案:160px

为啥是160px?

因为 HTML根标签默认的字体大小就是16px,rem的大小是相对于根标签HTML字号大小来算的

7.4、媒体查询

我们已经知道了em和rem的区别和用法

那么我们达到适配效果呢,让字体或者盒子间距图片等、在不同分辨率下也能放大或者缩小显示

手机屏幕大小不同,分辨率不同,如何设置不同的HTML标签字号?

使用媒体查询来编写CSS

什么是媒体查询

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

媒体查询写法

@media(媒体特性){选择器{css属性}
}
@media(width:320px){/*通过媒体查询,检测视口宽度 不同的视口设置不同的根标签文字大小*/html{font-size:32px}
}

设备宽度不同,HTML标签字号设置多少合适?

  • 设备宽度大,元素尺寸大
  • 设备宽度小,元素尺寸小

image-20240405181136955

不成文的规定

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

当然你划分成为20份也可以,当然还是10份比较好,因为比较好计算

image-20240405181545905

划分10份和划分20份有区别吗?

没有区别

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

如何确定rem的数值?

image-20240405182544200

这张图片中的图标为68px*29px

他是在屏幕宽度为375px下的显示的,

目标:计算68px是多少个rem?(假定设计稿适配375px视口)

N*37.5=68-N=68/37.5(有点迷糊)

默认是10等分、所以一份大概是37.5px,计算元素是多少rem直接除以37.5就好了

如下:

1rem=37.5px,那么几rem是68?78/37.5=1.81333333333333333333

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

  • 查看设计稿宽度---->确定参考设备宽度(视口宽度)---->确定基准根字号(1/10视口宽度)

7.5、flexible

前面我们讲了媒体查询,可以使用媒体查询来监视视口的变化?有什么弊端

image-20240405195448058

手机设备很多,屏幕尺寸不一,视口不仅仅只有这三个,解决方案是什么?

使用手淘团队开发的js框架flexible

什么是flexible.js

flexible.js是手淘开发的一个用来适配移动端的js框架

为啥要用flexible.js

媒体查询写起来麻烦,且检测不够精确,因此我们使用 flexible.js ,通过js 实时检测屏幕窗口的变化实现检测视口宽度。

核心原理

核心原理就是根据不同的视口宽度给网页中html根节点设置不同的font-size

image-20240405195726508

7.6、如何把设计稿的px转换为rem

flexible 能够修改html文字大小,修改文字大小: 当前屏幕 / 10 就是文字大小

例如: 当前屏幕 375px,则加了 flexible之后,html文字大小为 37.5px

我们的设计稿里面元素大小是固定的吗? 是 , 而是 px 单位 ,但是我们开发的时候,要使用 rem 才能适配。

那怎么把我们测量的px 转换为适配的rem呢?

直接使用测量的px值 /  37.5 就是 rem的值

后面我们学习vue开发的时候,所有的单位我们写 px。就足够了。 因为有脚手架帮我做转换

8、Less

8.1、什么是Less

Less是一个CSS预处理器, Less文件后缀是.less

扩充了 CSS 语言, 使 CSS 具备一定的逻辑性、计算能力。

常见的预处理器还有 Sass、Stylus

image-20240405231337618

8.2、安装Less编译插件Easy Less

Easy Less是一个VsCode插件

作用:less文件保存自动生成css文件

注意: html页面引入的还是css文件,而不是 less 文件

image-20240405231529801

8.3、体验Less的强大

建一个文件test.less

body {background-color: pink;
}

会自动在同级目录下编译出来一个css文件,名称为test.css

body {background-color: pink;
}

注意:浏览器不识别Less代码,目前阶段,网页要引入对应的CSS文件。

有同学会疑惑我直接建一个css文件直接往css里边写就好了,干嘛还要写这么一个文件,而且还要下插件编译

这不是脱裤子放屁多次一举嘛!因为Less,有很多强大的功能,计算,嵌套写法、变量,导入导出,会提高你css编写速度和准确率

当然这个对于用户来说,并没有什么区别,收益的是前端开发人员

8.4、Less注释

单行注释

  • 语法:// 注释内容

  • 快捷键:ctrl + /

块注释

  • 语法:/* 注释内容 */
  • 快捷键: shift + alt + A

8.5、Less运算

.box {width: 100px + 100;// 注意:单位的转换 计算的时候以第一个单位为准height: (100 / 37.5rem);// height: (100rem / 37.5);// height: 100px - 50;margin: (20px * 5) auto;padding: (10px / 5);border: 1px + 2 * 3 solid red;
}

注意点:

计算以第一个单位为准, 尽量写到最后一个数字上。 比如

 height: (100 / 37.5rem);

除法比较特殊,必须添加小括号。

计算别忘了先乘除后加减

8.6、Less嵌套

可以生成后代选择器

.father {width: 500px;height: 500px;background-color: purple;// 孩子.son {width: 200px;height: 200px;background-color: pink;p {color: red;}}
}

生成css之后:

.father {width: 500px;height: 500px;background-color: purple;
}
.father .son {width: 200px;height: 200px;background-color: pink;
}
.father .son p {color: red;
}

image-20240405232728949

我们在写伪类和伪元素的时候,经常使用 & 来代替父元素

.nav {width: 100px;height: 100px;background-color: pink;&::before {content: '1';}&:hover::before {color: red;}
}
.nav {width: 100px;height: 100px;background-color: pink;
}
.nav::before {content: '1';
}
.nav:hover::before {color: red;
}

8.7、less 变量

变量最大的优点是: 方便使用和修改。

语法:

@变量名:;
@fontSize: 16px;
@suibian: hotpink;
body {background-color: @suibian;
}
p {background-color: @suibian;}
div {color: @suibian;
}
nav {border: 1px solid @suibian;
}
body {background-color: hotpink;
}
p {background-color: hotpink;
}
div {color: hotpink;
}
nav {border: 1px solid hotpink;
}

8.9、小练习

需求1: 使用less 完成以下效果 大盒子 father 小盒子 son

63833046720

需求2: 鼠标经过大盒子,小盒子颜色变为 hotpink色

需求3: 请将 hotpink 颜色定义为一个变量。 @bgColor

-  建议: 小驼峰命名法     @backGroundColor
// 背景颜色变量
@backGroundColor: deeppink;
// 定义边框
@bd: 3px solid green;
.father {width: 500px;height: 500px;background-color: pink;display: flex;justify-content: center;align-items: center;border: @bd;.son {width: 200px;height: 200px;background-color: skyblue;border: @bd;}// &:hover .son {//   background-color: hotpink;// }&:hover {.son {background-color: @backGroundColor;}}
}

8.1、less导入

less的导入实际 是 less 文件的导入。

@import './变量.less';
@import url(./变量.less);

使用less导入的好处是: 减少了html页面 的 link标签数量。

8.2、less 导出

配置EasyLess插件, 实现所有Less有相同的导出路径

配置插件: 设置 → 搜索EasyLess → 在setting.json中编辑 → 添加代码(注意,必须是双引号)

image-20240405233218073

  "less.compile": {"out": "../css/" // 设置导出css路径},

手动给每个less文件指定导出

导出必须写到第一行

// out: 路径/文件名
// out: ./mycss/pink.css

设置导出: 当面目录下,创建一个 mycss 文件夹, 生成 一个 pink.css (做了改名)

// out: ./mycss/

设置导出: 当面目录下,创建一个 mycss 文件夹, 生成 一个 跟less一样的文件名(原名)

8.3、less 禁止导出

有些被其他Less导入的Less文件是不需要导出的,我们就可以在首行设置这个东西

// out: false

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/795542.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Yalmip使用教程(7)-求解器的参数设置

博客中所有内容均来源于自己学习过程中积累的经验以及对yalmip官方文档的翻译:https://yalmip.github.io/tutorials/ 这篇博客将详细介绍yalmip工具箱中常用的求解器设置选项。 1.求解器的基本设置 使用sdpsettings函数可以对求解的相关参数进行设置。最常用的设置…

Java学习day6-集合

集合指一组用于储存和操作数据的类和接口,提供各种数据结构和算法,以在程序中高效地管理和操作数据 特点:与数组相比,集合可以自动扩容,只需向其中添加元素即可(与Cvector类似);数组…

软考之零碎片段记录(七)+复习巩固(二)

一、上新 1. 有向图 从顶点A到顶点B的边,不等于从B到A的边。 2. 广度优先 遍历开始节点(第一层)的邻节点(从左至右顺序),邻接点设为第二层根据1中遍历邻接点从左往右的顺序遍历。 bilibili视频《广度优…

《C++程序设计》阅读笔记【5-引用】

🌈个人主页:godspeed_lucip 🔥 系列专栏:《C程序设计》阅读笔记 本文对应的PDF源文件请关注微信公众号程序员刘同学,回复C程序设计获取下载链接。 1 引用1.1 概念1.2 和引用相关的操作1.2.1 什么能被引用 1.3 用引用传…

WebKit结构揭秘:探秘网页渲染的魔法之源

一、WebKit之心:渲染引擎的魔力 WebKit的渲染引擎是其核心所在,它犹如一位技艺高超的魔法师,将HTML、CSS和JavaScript的魔法咒语转化为绚丽的网页画面。它解析代码,绘制页面,让网页内容跃然屏上,展现出无尽…

ROS 2边学边练(15)-- 写一个简单的服务(C++)

前言 此篇我们即将编写一个简单的服务(service)通信例子,客户端节点向服务端节点发出请求(.srv文件中规定了通信的数据结构格式),服务端节点收到请求后将结果回复给客户端节点,一问一答&#xf…

Unity类银河恶魔城学习记录12-4 p126 Item Tooltip源代码

Alex教程每一P的教程原代码加上我自己的理解初步理解写的注释,可供学习Alex教程的人参考 此代码仅为较上一P有所改变的代码 【Unity教程】从0编程制作类银河恶魔城游戏_哔哩哔哩_bilibili UI.cs using System.Collections; using System.Collections.Generic; usi…

【面经】interrupt()、interrupted()和isInterrupted()的区别与使用

📝个人主页:五敷有你 🔥系列专栏:面经 ⛺️稳中求进,晒太阳 interrupt方法 如果打断线程正在sleep,wait,join会导致被打断的线程抛出InterruptedException,并清除打断标记。如…

Redis的配置文件详解

单位:Redis配置对大小写不敏感! 注意这里:任何写法都可,不区分大小写。 units are case insensitive so 1GB 1Gb 1gB are all the same.包含:搭建Redis集群时,可以使用includes包含其他配置文件网络&…

关于 elf loader 的编写

可以使用如下命令观看 elf 文件的信息 readelf -a build/ramdisk.img | vim -在编写 elf loader 的时候,实际上只有下图这一部分 “Program Headers” 是有用的 凡是类型为 “LOAD” 的就是需要加载进内存的部分 所以,只要把这些部分加载进内存里&…

数据库不用mmap

你确定你想用 MMAP 实现数据库么?_哔哩哔哩_bilibili MMAP 的随机读与顺序读的性能表现不好,以及对于写主要是不可控的刷入时机以及代码冗余,所以 MMAP 不适合在数据库中使用。 mmap是posix系统调用,它提供由操作系统管理内存映…

(C)1008 数组元素循环右移问题

1008 数组元素循环右移问题&#xff1a; 问题描述 输入样例&#xff1a; 6 2 1 2 3 4 5 6 输出样例&#xff1a; 5 6 1 2 3 4 解决方案&#xff1a; #include<stdio.h> #include<string.h> #include<math.h> int main(){int n,k,flag,y,x,final;int a[10000…

Flutter Boost 3

社区的 issue 没有收敛的趋势。 设计过于复杂&#xff0c;概念太多。这让一个新手看 FlutterBoost 的代码很吃力。 这些问题促使我们重新梳理设计&#xff0c;为了彻底解决这些顽固的问题&#xff0c;我们做一次大升级&#xff0c;我们把这次升级命名为 FlutterBoost 3.0&am…

合理早餐选择,稳定糖尿病血糖。

对于糖尿病患者来说&#xff0c;饮食管理是治疗的重要一环。不合理的早餐选择会导致血糖的波动。很多糖尿病朋友按时吃药&#xff0c;但是血糖就是稳定不住&#xff0c;之前看过一个例子&#xff0c;北京崇文门医院朱学敏主任接诊过一个患者&#xff0c;那个患者按时吃药&#…

LaTeX 空格与换行

任意多个空格与一个空格的功能相同。只有字符后面的空格是有效的&#xff0c;每行最前面的空格被忽略。单个换行被视作一个空格&#xff0c;连续两个换行表示分段。~被称作一种不可打断的空格&#xff0c;排版系统不会在这种空格之间换行。西文的逗号、句号和分号等标点后面应该…

Java | Leetcode Java题解之第8题字符串转换整数atoi

题目&#xff1a; 题解&#xff1a; class Solution {public int myAtoi(String str) {Automaton automaton new Automaton();int length str.length();for (int i 0; i < length; i) {automaton.get(str.charAt(i));}return (int) (automaton.sign * automaton.ans);} …

Android Studio学习10——资源res的使用

一、String,StringArray的使用 一次修改&#xff0c;多出生效 String StringArray 二、color的使用 颜色代码对应表 和上面的相似用法 三、Dimen(尺寸)的使用 用的少&#xff0c;一般直接写尺寸 四、如何写一个drawable作为背景 五、如何写一个可以改变的drawable(按钮按下…

IP地址:是给主机配置的,还是给网卡配置的?

在探索网络的奥秘时&#xff0c;我们经常会遇到一个看似简单但又复杂的问题&#xff1a;IP地址到底是配置在主机上&#xff0c;还是配置在网卡上&#xff1f;为什么我们通常说的是“主机IP地址”呢&#xff1f;让我们一起深入探讨。 1. 网卡与IP地址 &#x1f5a5;️&#x1f…

利用OllyDbg对程序内容进行修改实验

1.双击运行exe文件&#xff0c;出现如下弹窗 2.用ollydbg工具打开该执行文件&#xff0c;页面显示如下 3.在注释窗口执行以下操作 4.双击运行exe文件时&#xff0c;显示”Copied!”所以接下来在注释里找到这个字样&#xff0c;如下&#xff0c;我们需要把对话框中的内容修改为“…

SQL语句学习+牛客基础39SQL

什么是SQL&#xff1f; SQL (Structured Query Language:结构化查询语言) 是用于管理关系数据库管理系统&#xff08;RDBMS&#xff09;。 SQL 的范围包括数据插入、查询、更新和删除&#xff0c;数据库模式创建和修改&#xff0c;以及数据访问控制。 SQL语法 数据库表 一个…