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

news2025/1/21 0:57:46

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:10em
  height:10em
  background-color:pink
  font-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.coloradmin.cn/o/1571651.html

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

相关文章

Web大并发集群部署之集群介绍

一、传统web访问模型 传统web访问模型完成一次请求的步骤 1)用户发起请求 2)服务器接受请求 3)服务器处理请求(压力最大) 4)服务器响应请求 传统模型缺点 单点故障; 单台服务器资源有限&…

excel统计分析——多元线性回归

参考资料:生物统计学 多元线性回归(multiple linear regression)是具有一个因变量或多个(两个或以上)自变量的线性回归,是直线回归的拓展,其模型和计算过程与直线回归类似,只是在计算…

【软件工程】测试规格

1. 引言 1.1简介 本次的测试用例是基于核心代码基本开发完毕,在第一代系统基本正常运行后编写的,主要目的是为了后续开发与维护的便利性。 该文档主要受众为该系统后续开发人员,并且在阅读此文档前最后先阅读本系统的需求文档、概要设计文…

Qt事件学习案例

视频链接 https://www.bilibili.com/video/BV18B4y1K7Cs?p7&spm_id_frompageDriver&vd_sourcefa4ef8f26ae084f9b5f70a5f87e9e41bQt5跟着视频做即可,Qt6部分代码需要改动,改动的地方注释有写 素材 百度云 链接:https://pan.baidu.com/s/158j…

K8S - Deployment 的版本回滚

当前状态 先看deployment rootk8s-master:~# kubectl get deploy -o wide --show-labels NAME READY UP-TO-DATE AVAILABLE AGE CONTAINERS IMAGES …

蓝桥杯嵌入式(G431)备赛笔记——LED

cubeMX配置: 原理图,其中PD2高电平使能锁存器,PC8-15默认给高电平,放置上电初始化LED亮 74HC573是八路输出锁存器 1脚是使能,低电平有效,高电平输出高阻 2~9是输入,PC8-PC15 19~12是输出 11是锁存,即PD2: 高电平是同步,即输出跟随输入变化 低电平锁存,即输出不再改变 …

RUST Rover 条件编译 异常处理

按官方处理发现异常 会报异常 error: failed to parse manifest at C:\Users\topma\RustroverProjects\untitled2\Cargo.toml 修改模式如下才能正常编译 网上说明 这样处理 https://course.rs/cargo/reference/features/intro.html RUST 圣经里描述 [features] print-a []…

如何用putty通过ssh连接ubuntu

1. 下载和安装PuTTY 访问PuTTY官网下载PuTTY的最新版本。 2. 打开PuTTY 解压下载的文件后,找到PuTTY文件并双击打开。 3. 配置SSH连接 在ubuntu下安装ssh服务在安装ssh时,我一直遇到一个问题,原因是我的虚拟机连不上网,反复实…

Linux之shell脚本编辑工具awk

华子目录 概念工作流程工作图流程(按行处理) awk程序执行方式1.通过命令行执行awk程序实例 2.awk命令调用脚本执行实例 3.直接使用awk脚本文件调用实例 awk命令的基本语法格式BEGIN模式与END模式实例awk的输出 记录和域(记录表示数据行&#…

若依:一个基于Spring Boot、Spring Security、JWT、Vue和Element的全部开源快速开发平台

若依后台管理系统:一个基于Spring Boot、Spring Security、JWT、Vue和Element的全部开源快速开发平台 一、引言 随着软件开发技术的发展,前后端分离的开发模式逐渐成为主流。这种模式能够提高开发效率,降低维护成本,使前后端工程…

SketchUp Pro 2024 for mac 草图大师 专业的3D建模软件

SketchUp Pro 2024 for Mac是一款功能强大的三维建模软件,适用于Mac电脑。其简洁易用的界面和强大的工具集使得用户可以轻松创建复杂的3D模型。 软件下载:SketchUp Pro 2024 for mac v24.0.483 激活版下载 SketchUp Pro 2024 for Mac支持导入和导出多种文…

leetcode.面试题 02.07. 链表相交

题目 给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点,返回 null 。 图示两个链表在节点 c1 开始相交: 思路 假a在链表A上移动,b在链表B上移动,a移动完在B上开始&…

人脸识别:Arcface--loss+code

之前只接触过传统方法的人脸识别算法,本以为基于深度学习的方法会使用对比损失之类的函数进行训练,但是Arcface算法基于softmax进行了创新,本文未深究其详细的loss公式原理,在大致明白其方向下,运行了代码,…

加速度:电子元器件营销网站的功能和开发周期

据工信部预计,到2023年,我国电子元器件销售总额将达到2.1万亿元。随着资本的涌入,在这个万亿级赛道,市场竞争变得更加激烈的同时,行业数字化发展已是大势所趋。电子元器件B2B商城平台提升数据化驱动能力,扩…

云服务器ECS租用价格表报价——阿里云

阿里云服务器租用价格表2024年最新,云服务器ECS经济型e实例2核2G、3M固定带宽99元一年,轻量应用服务器2核2G3M带宽轻量服务器一年61元,ECS u1服务器2核4G5M固定带宽199元一年,2核4G4M带宽轻量服务器一年165元12个月,2核…

docker的安装及入门指令

目录 一、将docker安装到云服务器步骤 1.更新系统yum版本 2.安装所需依赖 3.添加docker仓库设置(使用的是阿里云) 4.安装docker引擎 5.启动docker并开启自动启动 6. 检查是否安装成功,成功会显示相应版本,否则安装失败 二、docker常用命令 1.从…

Chatgpt掘金之旅—有爱AI商业实战篇|专业博客|(六)

演示站点: https://ai.uaai.cn 对话模块 官方论坛: www.jingyuai.com 京娱AI 一、AI技术创业博客领域有哪些机会? 人工智能(AI)技术作为当今科技创新的前沿领域,为创业者提供了广阔的机会和挑战。随着AI技…

微信小程序短链接工具推荐

现在微信小程序大行其道,但工作中大部分人选择了短链接的方式来推广微信小程序,那么微信小程序短链接工具哪个好?今天就分享一篇从网上看到的关于《微信小程序短链接工具推荐》文,作者是souki,一起来看看吧! 一、缩链 1、生成方…

前端面试高频: 理解 React/Vue 中 Key 的作用

一: 引言 在 React 或 Vue 项目中,我们经常在列表组件中使用key属性。key是给每一个vnode的唯一id,它在列表渲染和虚拟 DOM 操作中扮演着重要的角色。 当我们在渲染一个包含多个相同子组件的列表时,如果没有使用 key,React 或 Vue…

Django--admin 后台管理站点

Django最大的优点之一,就是体贴的提供了一个基于项目model创建的一个后台管理站点admin。这个界面只给站点管理员使用,并不对大众开放。虽然admin的界面可能不是那么美观,功能不是那么强大,内容不一定符合你的要求,但是…