常用的单位有哪些?以及px em rem区别

简介: 常用的单位有哪些?以及px em rem区别

1.px:固定的像素,一旦设置了就无法因为适应页面大小而改变,因此px通常被用来实现固定大小的布局效果

2.em:em相对于父元素

相对长度单位,表示相对于元素字体大小的倍数。

例如,如果一个元素的字体大小为16px,那么1em就等于16px。

另外,如果一个元素没有设置字体大小,那么em的值就会继承其父元素的字体大小。

因此,em通常被用来实现相对于字体大小的布局效果。

3.rem:rem相对于根元素

一、rem

rem是全部的长度都相对于根元素,根元素是谁?<html>元素。通常做法是给html元素设置一个字体大小,然后其他元素的长度单位就为rem。

<!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">
    <title>Document</title>
    <style>
        html {
            font-size: 10px;
        }
        div {
            font-size: 4rem;  /* 40px */
            width: 20rem;     /* 200px */
            height: 20rem;
            color: black;
            background-color: darkcyan;
        }
        p {
            font-size: 2rem;  /* 20px */
            width: 10rem;
            height: 10rem;
            color: blue;
            background-color: purple;
            margin: 0;
        }
        span {
            font-size: 1.5rem;
            width: 7rem;
            height: 6rem;
            display: block;
            color: red;
            background-color: sandybrown;
        }
    </style>
</head>
<body>
    <div>
        父元素div
        <p>
            子元素p
            <span>孙元素span</span>
        </p>
    </div>
</body>
</html>

二、em

子元素字体大小的em是相对于父元素字体大小

元素的width/height/padding/margin用em的话是相对于该元素的font-size

<!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">
    <title>Document</title>
    <style>
        div {
            font-size: 40px;
            width: 7.5em;  /* 300px */
            height: 7.5em;
            background-color: gray;
        }
        p {
            font-size: 0.5em; /* 20px */
            width: 7.5em;     /* 150px */
            height: 7.5em;
            color: blue;
            background-color: tan;
            margin: 0;
        }
        span {
            font-size: 0.5em;
            width: 7em;
            height: 6em;
            background-color: #fff;
            display: block;
            color: red;
        }
    </style>
</head>
<body>
    <div>
        父元素div
        <p>
            子元素p
            <span>孙元素span</span>
        </p>
    </div>
</body>
</html>

应用场景:

1.像素(px):用于元素的边框或定位。

2.em/rem:用于做响应式页面,不过我更倾向于rem,因为em不同元素的参照物不一样(都是该元素父元素),所以在计算的时候不方便,相比之下rem就只有一个参照物(html元素),这样计算起来更清晰。

总结 :

1.rem 和 em 单位是由浏览器基于你的设计中的字体大小计算得到的像素值。

2、em 单位基于使用他们的元素的字体大小。

3、rem 单位基于 html 元素的字体大小。

4、em 单位可能受任何继承的父元素字体大小影响

5、rem 单位可以从浏览器字体设置中继承字体大小。

6、使用 em 单位应根据组件的字体大小而不是根元素的字体大小。

7、在不需要使用em单位,并且需要根据浏览器的字体大小设置缩放的情况下使用rem。

8、使用rem单位,除非你确定你需要 em 单位,包括对字体大小。

9、媒体查询中使用 rem 单位

10、不要在多列布局中使用 em 或 rem -改用 %。

11、不要使用 em 或 rem,如果缩放会不可避免地导致要打破布局元素。

注意点:

1.样式的reset中需先设置html字体的初始化大小为50px,这是为了防止js被禁用或者加载不到或者执行错误。

2.而做的兼容样式的reset中需先设置body字体的初始化大小为16px,这是为了让body内的字体大小不继承父级html元素的50px,而用系统默认的16px


相关文章
|
编解码 前端开发 小程序
CSS中rpx、px、em、rem、%、vh、vw各自都代表什么
CSS中rpx、px、em、rem、%、vh、vw各自都代表什么
549 0
|
弹性计算 安全 Linux
SSL-VPN和客户端配置|学习笔记
快速学习SSL-VPN和客户端配置
SSL-VPN和客户端配置|学习笔记
|
4月前
|
机器学习/深度学习 编解码 人工智能
面壁开源多模态新旗舰MiniCPM-V 4.5,8B 性能超越 72B,高刷视频理解又准又快
今天,面壁智能正式开源 8B 参数的面壁小钢炮 MiniCPM-V 4.5 多模态旗舰模型,成为行业首个具备“高刷”视频理解能力的多模态模型,看得准、看得快,看得长!高刷视频理解、长视频理解、OCR、文档解析能力同级 SOTA,且性能超过 Qwen2.5-VL 72B,堪称最强端侧多模态模型。
475 9
|
6月前
|
Ubuntu Linux 数据安全/隐私保护
Windows中安装WSL 2和Ubuntu系统的教程
回看这一路,有趣吧?你已经跨界成为了一个Windows和Linux的桥梁。期待在代码的世界里,把一切玩得风生水起!
345 13
【Typora】如何使用Markdown插入一段文字,部分左对齐,部分右对齐
如何在Markdown编辑器Typora中使用HTML语法实现同一行内文字的左对齐和右对齐布局。
914 1
|
存储 NoSQL 中间件
单点登录的原理、实现、以及技术方案比较详解
本文详细介绍单点登录(SSO)的定义、原理、实现细节,探讨其在大型网站中的应用,帮助读者理解如何通过分布式Session实现高效的用户认证与授权。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
单点登录的原理、实现、以及技术方案比较详解
Px,em,rem的区别
【10月更文挑战第10天】 Px,em,rem的区别
1065 2
|
小程序 JavaScript 开发者
微信小程序构建npm
微信小程序构建npm
829 4
|
小程序 容灾
单点登录模式
单点登录模式
1220 0
|
人工智能 JavaScript 开发工具
【完全免费】VS Code 最好用的 12 款 AI 代码提示插件!!!
🎉 探索12款免费VSCode AI代码提示插件:Codeium、Codegeex、CodeFuse、TONGYI Lingma、Comate、iFlyCode、Fitten Code、Bito AI、Mintlify Doc Writer、Kodezi AI、aiXcoder、IntelliCode。这些插件提供智能补全、代码生成、注释、优化,支持多种语言,提升编程效率!🚀👩‍💻👨‍💻
18574 0