前端基础(六)_CSS单位

简介: 本文介绍了CSS中常用的单位,包括像素(px)、相对长度单位(em、rem)、百分比(%)、视窗宽度(vw)和视窗高度(vh)。文章通过示例代码展示了这些单位在实际布局中的应用,解释了它们各自的特点和使用场景。例如,em和rem单位与字体大小相关,百分比单位与父元素的尺寸相关,而vw和vh单位则与浏览器视窗的宽度和高度相关。

CSS单位

px

px 相对于显示器屏幕分辨率而言,值固定,计算比较容易

em

em 相对长度单位 和父元素的字号大小有关系 font-size属性值而言
浏览器默认字号为16像素,未经调整的浏览器都符合1em=16px

div p都设置了font-size 那em就是随p
特点:值不固定;会继承父元素的字号大小

rem

rem 相对根元素(html)字体大小的长度单位 是css3新增的单位
浏览器的默认情况下 1rem=16px 在IE8及更早浏览器不兼容

%

% 相对父级长度单位

vw、vh

vw,全屏幕宽为100vw;vh,全屏幕高为100vh。会随着浏览器窗口大小的变化而动态计算宽/高度值

例子1:px、rem、em

<!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>我的第一个页面</title>
  <style>
    * {
    
      padding: 0;
      margin: 0;
      /* 根节点 font-size  16px */
    }

    div {
    
      width: 500px;
      font-size: 20px;
    }

    p {
    
      /* 前边留出40px的位置,因为父节点的字体大小为20px  所以对于p的em单位 1em === 20px */
      text-indent: 2em;
    }

    .p1 {
    
      /*根节点的font-size为16,rem单位是根据根节点font-size来进行变化的,所以这个2rem为32px*/
      font-size: 2rem;
    }
  </style>
</head>

<body>
  <div>
    font-size:20px
    <p>font-size:20px 抱怨是这个世界上最无用的东西。与其怨天尤人,不如付出切实的行动,去改变困扰你的糟糕状况。</p>
    <p class="p1">font-size:32px 抱怨是这个世界上最无用的东西。与其怨天尤人,不如付出切实的行动,去改变困扰你的糟糕状况。</p>
  </div>
</body>

</html>

在这里插入图片描述
这是div里面的默认字体大小20px。
在这里插入图片描述
针对于第一个p元素,首先会继承父级div元素的字体大小样式,所以font-size为20px,这个时候出现了text-indent属性为2em,em为相对单位,如果当前元素有自己font-size,则自己一个字体的大小为1em,如果没有的话,则会招父级元素的大小,所以前面会空出40px的位置。
在这里插入图片描述
针对第二个p元素,也就是类名为p1的元素,他的font-size我们重新定义了一个为2rem,rem单位是相对单位,相对于根元素的单位,根元素的font-size为16px,所以p1的font-size为32px,同时继承了text-indent为2em,同上em先看本元素有没有字体大小,用的话用自己的,没有的话用父级的,所以前面预留32*2的位置。

例子2:%、vw、vh

<!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>我的第一个页面</title>
  <style>
    * {
    
      padding: 0;
      margin: 0;
      /* 根节点 font-size  16px */
    }

    .div1 {
    
      width: 500px;
      background-color: pink;
      margin-bottom: 20px;
    }

    .p1 {
    
      /* 相对于父级元素宽度的50%  一半  */
      width: 50%;
      background-color: #ccc;
      /* 实现水平居中 */
      margin: 0 auto;
    }

    .div2 {
    
      /* 相当于窗口宽度的30%,将浏览器窗口的宽分为100分,它占30份 */
      width: 30vw;
      /* 相当于窗口高度的20%,将浏览器窗口的高分为100分,它占20份 */
      height: 20vh;
      background-color: #ccc;
    }
  </style>
</head>

<body>
  <div class="div1">
    <p class="p1">抱怨是这个世界上最无用的东西。与其怨天尤人,不如付出切实的行动,去改变困扰你的糟糕状况。</p>
  </div>
  <div class="div2">
    <p class="p2">抱怨是这个世界上最无用的东西。与其怨天尤人,不如付出切实的行动,去改变困扰你的糟糕状况。</p>
  </div>
</body>

</html>

在这里插入图片描述
p1的宽度为div1宽度的一半50%也就是250px
div2的宽度为浏览器窗口宽的30,高的20

目录
相关文章
|
1月前
|
前端开发 JavaScript C++
揭秘Web前端CSS引入秘籍:Link vs @import,你的选择决定页面加载速度,你选对了吗?
【8月更文挑战第26天】本文探讨了Web前端开发中CSS的引用方法,主要包括行内样式、内部样式表及外部样式表三种形式。重点对比了外部样式表中的`&lt;link&gt;`和`@import`两种引入方式。`&lt;link&gt;`作为HTML元素,在页面加载初期就开始加载样式资源,支持并行加载,对提高页面加载速度有益。而`@import`作为一种CSS规则,仅能在CSS文件中使用,其引入的样式表会在页面完成加载后才开始加载,可能导致渲染延迟且不支持并行加载。因此,在多数情况下,推荐采用`&lt;link&gt;`方式引入外部样式表,以确保更佳的性能表现和浏览器兼容性。
63 2
|
15天前
|
前端开发
【前端web入门第四天】02 CSS三大特性+背景图
本文详细介绍了CSS的三大特性:继承性、层叠性和优先级,并深入讲解了背景图的相关属性,包括背景属性、背景图的平铺方式、位置设定、缩放、固定以及复合属性。其中,继承性指子元素自动继承父元素的文字控制属性;层叠性指相同属性后定义覆盖前定义,不同属性可叠加;优先级涉及选择器权重,包括行内样式、ID选择器等。背景图部分则通过具体示例展示了如何设置背景图像的位置、大小及固定方式等。
236 91
|
1天前
|
前端开发
前端基础(五)_CSS文本文字属性、背景颜色属性
本文详细介绍了CSS中关于文本和背景颜色的样式属性。包括字体大小、字体族、字体加粗、字体样式、文本行高、`font`属性、文本颜色、文本对齐方式、文本装饰线、首行缩进等文本属性,以及背景颜色、背景图片、背景重复、背景位置等背景属性。文章通过示例代码展示了这些属性的具体应用和效果。
7 3
前端基础(五)_CSS文本文字属性、背景颜色属性
|
1天前
|
前端开发
前端基础(九)_CSS的三大特征
本文详细解释了CSS的三大特性:层叠性、继承性和优先级,并通过实例演示了样式冲突、叠加和选择器优先级的应用。
7 2
前端基础(九)_CSS的三大特征
|
15天前
|
前端开发
【前端web入门第三天】02 CSS字体和文本
本文详细介绍了CSS中字体和文本的相关属性。字体部分涵盖字体大小、粗细、样式、行高、字体族及`font`复合属性,通过具体示例展示了如何设置和使用这些属性。文本部分则讲解了文本缩进、对齐方式、修饰线及文字颜色等属性,并提供了实用的代码示例。此外,还简要介绍了调试工具中的一些细节,如错误属性标识和属性生效状态的控制。
49 28
|
1天前
|
前端开发
前端基础(四)_CSS层叠样式表_什么是css_css样式的引入方式_样式表的优先级_样式选择器
本文详细介绍了CSS(层叠样式表)的基本概念、语法规则、引入方式、样式表的优先级和样式选择器。文章解释了CSS的作用,展示了如何在HTML中通过行内样式、内部样式和外部样式引入CSS,讨论了不同CSS选择器的优先级和如何确定最终的样式应用。此外,还强调了使用`!important`规则时的优先级高于行内样式。
12 1
|
15天前
|
前端开发 JavaScript
【前端web入门第三天】01 css定义和引入方式 四种标签选择器
本文档详细介绍了CSS的基础知识及其应用。内容涵盖了CSS的定义、CSS在HTML中的引入方式,包括内部样式表、外部样式表及行内样式表的使用场景与方法。此外,还深入解析了不同种类的选择器:标签选择器、类选择器、ID选择器以及通配符选择器的功能与应用场景,并提供了实例帮助理解。最后,通过具体的新属性示例,指导如何使用这些选择器来实现基本的盒子绘制。适合初学者系统学习CSS。
33 15
|
14天前
|
前端开发
|
14天前
|
前端开发
【前端web入门第六天】01 CSS浮动
这是关于CSS布局第六天学习目标的介绍,主要解决多个`&lt;div&gt;`标签在同一行显示的问题,即一个在左边,另一个在右边。文中介绍了标准流、浮动及flex布局的概念,重点推荐使用flex布局。文章详细讲解了浮动的基本使用、布局技巧及清除浮动的方法,包括额外标签法、单伪元素法、双伪元素法和`overflow`隐藏法,并提供了示例代码帮助理解。
|
1月前
|
编解码 前端开发 开发者
【前端设计达人必备】揭秘CSS尺寸单位的魔力:从基础到实战,打造灵动响应式网页!
【8月更文挑战第26天】本文深入探讨了CSS中常用的尺寸单位,包括像素(px)、百分比(%)、视窗单位(vw/vh/vmin/vmax)、可伸缩相对单位(em/rem)以及Flexbox和Grid中的fr单位。通过具体案例展示了每种单位的特点及其适用场景。像素适用于固定尺寸元素;百分比和em/rem利于构建响应式布局;视窗单位适合全屏设计;fr单位则能有效管理复杂网格布局的空间分配。掌握这些单位有助于开发者设计出更加灵活、高质量的网页布局。
37 4