整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

CSS进阶知识扫盲

CSS进阶知识扫盲


SS其实远比我们想象的更复杂、他的任意一个点拿出来可能都可以写出一篇篇幅不小的文章,往往就能见微知著。所以CSS不仅仅局限于他的名字,层叠样式表,更像是一个世界,一个网页中必不可少的重要组成。

围绕着上面的CSS体系,当然上面的图可能还不够全面,但是也能说明CSS的主要构成了。我们简单说下可能其中一些不为人知的“隐藏属性”,先留下一个大体的印象,拓展自己的CSS学习体系,后续才能慢慢深入其中。

本篇也是笔者结合《CSS世界》、《CSS权威指南》上下册、《CSS揭秘》后,总结的一些平时自己忽略的,或者说根本就不了解的地方,实地敲代码在浏览器中实践而来。

文本排版

先来说字体,声明字体很简单,font-family声明就完事了,但是有时我们可能会看到这样的声明:

h1 {
  font-family: -apple-system,system-ui,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif,BlinkMacSystemFont,Helvetica Neue,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Arial;
}

这么一大串到底是几个意思呢,其实只要知道这个font-faimly属性中包含两种类型值就能明白了,一种是字体名称,一种叫做字体族。顾名思义,字体族就是所有字体的一个分类,在CSS世界中一般有以下几种字体族:

  • 衬线字体。指的就是笔画开始、结束处有额外的装饰,并且笔画粗细不同。
  • 无衬线字体。就是没有装饰,笔画粗细相同。
  • 等宽字体。字形的宽度都相等。
  • 草书字体。模仿人类手写的字体。
  • 奇幻字体。没有归于以上四类字体的其他字体。

所以诸如上面的声明中的sans-serif、Helvetica指的是字体族,前者是衬线字体,后者是无衬线字体。那么这其中的意思就很明确了,如果系统中有前面的字体,那就使用前面的字体,如果没有的话,尝试使用后面的衬线字体,如果没有,则继续往后面的声明中寻找可用字体。

我自己是一名从事了多年开发的web前端老程序员,目前辞职在做自己的web前端私人定制课程,今年我花了一个月整理了一份最适合2020年学习的web前端学习干货,各种框架都有整理,送给每一位前端小伙伴,想要获取的可以关注我的头条号并在后台私信我:前端,即可免费获取。

继承

一般文本类的属性都是可以继承的,例如color,font-size,font-family等。

与之对应有些属性时不能继承的,例如border,padding,margin,background等。其实也很好理解这些属性为何不能继承,因为一旦这些属性可以继承,那么会影响到了整个布局,例如,我们在父元素上加个边框,但是其子元素,后代元素都继承了边框,那就不得不去写更多的代码来消除继承的影响,这样的结果肯定不是CSS设计的初衷。

line-height

首先需要明确的是line-height是作用在行内元素或者是行内块级元素上的,我们声明在块级框上的line-height实际也是作用于块级框中的内容的,因此经常可能看到会这么使用:

div {
  line-height: 100px;
  font-size: 20px;
}

于是看到了这样的效果:

可能下意识的就以为line-height就是作用在块级盒子上的。实际上呢,他是作用于块级盒子中的文本上的,如果去除 div 中的文本就会看到其高度就没有 100px 了,文本也是行内元素,这点想必都是清楚的。

另外则是line-height的值可以为数值、百分比以及长度值,长度值也包括例如em这样的相对单位。当值不是具体长度值的时候,也就是为数值或者是百分比的时候,相对计算的是其font-size属性,如果font-size的值为16px,则line-height: 1.5的值就为16 * 1.5,就是24px,百分比值的时候也是这么计算的,不过需要注意的是,百分比值在继承的时候,会相对当前的font-size来计算,也就是说如果父子元素的font-size值不同,那么line-height计算出来的值也是不一样的。如果数值的话则没有这个问题,始终都是相对于数值来计算的。

另外经常会看到这样的用法,让文字垂直居中:

div {
  line-height: 100px;
  height: 100px;
}

实际就是只需要line-height就能实现垂直居中,和下面的高度没有什么关系,而为什么这么设置可以垂直居中呢?这就要来看line-height设置的属性究竟如何作用的。还是来看上面的图,当设置line-height的时候,div 的高度就被设置为了 100px,但是这个值是这么分配的,用100px - 1em得到的值分成两份,分别加到字体的上部分和下部分的区域,这样字体就平分上下区域,形成一种垂直居中的情况,1em就是字体的大小。当然这里其实是近似的垂直,因为不同字体实际占据的1em的大小是不一样的,因此分配上下半行高的时候,会有存在偏差,除此之外,下面说的一种属性也会影响到这种情况。

strut(支柱)

这是个在CSS中看不见,但却无处不在,有些书中将之称为空白节点。他是支撑内联文本存在的支柱。可以通过这种方法来看到他:

.line1 {
  line-height: 0;
  border: 1px solid red;
  font-size: 20px;
}


根据上面学到的关于line-height的知识,当设置为 0 时,文本行高为 0,那么外面的包含块,也就是父元素理论上也应该是 0,但是我们发现这里的高度是 2,其实这就是所谓支柱的存在了,存在于每个内联盒子的前面,先记住他,下面会用到。

vertical-align

<div class="line3">
  <img src="../../../assets/css_mindgraphy.png" width="100">
</div>

于是我们发现图片的下面出现了一点间隙,针对这种情况,vertical-align就可以出场了,只要将vertical-align设置为除默认值之外的位置值就可以了。

.line3 > img {
  vertical-align: top;
}


可以看到图片下面的间隙没有了,当然这里除了使用vertical-align以外,还可以设置line-height: 0、font-size: 0都能去解决这个问题。原因就在于上面说到strut, 图片是内联元素,因此其也存在一个看不见的文本节点,相当于这样

噢~这样就知道应该是默认的行高起的作用,对了,还有vertical-align的作用,因为其默认值是baseline也就是基线对齐,可以看到图片底部可以文本的底部对齐了,那么当设置vertical-align: top、line-height: 0或者font-size: 0,前者相当于将基线对齐变成了顶部对齐,自然不会出现下面的间隙了,后两者则是将行高去掉,另外则是隐藏了文本大小,那么自然间隙也都不存在了。

除此之外,我们还有一种方法能够解决这个问题,就是直接改变图片的display值,将其设置为块级元素,那么上面所说的空白节点strut自然就不存在了,也能解决这个问题。不过这里改变了display值,可能会影响到布局,所以还是推荐使用上面几种办法。

vertical-align除了设置位置值,也就是除了top,middle,bottom这些关键字,还可以设置具体的数值,百分数,也可以设置负数值,负数值其实就是向下偏移指定的值,百分数就是相对line-height的值设定。

CSS的全局关键字

全局关键字就是所有的属性都能使用的属性值,总共是有三个inherit,initial,unset。这些关键字是CSS3才出现的,在IE11以前和Opera Mini是不支持的。

inherit 就是打破了上面的继承限制,只要属性值设置为 inherit,那么就能从父元素继承这个属性。

initial 则是将属性设置为初始值,主要是用于那些没有预定义的初始值的属性,例如 color 属性,默认是取决于用户代理,就是用户设置的某个颜色值,而设置为 initial 则会将字体颜色变成黑色。

unset 则是前两个关键字的替代,就是对于继承的属性来说,unset 就表示 inherit,而对于不继承的属性则表示 initial。

还有一个特殊属性 all 就只支持这三个关键字。all 表示除了 direction 和 unicode-bidi 之外的所有的属性。因此如果设置了 all: inherit 则表示除了上述两个属性外,其他所有的CSS属性都从其父元素继承。

选择符

这里选择符,就是平常所说的选择器。选择器的种类非常多,但大多就是上面列举的几种,除此之外,还有一些平时可能忽略的通用选择符:

* {
  box-sizing: border-box;
}

看起来非常的简单,但是滥用他会造成一些意向不到的结果。首页就是他会给所有的元素都添加上对应的属性,即使这个元素压根就用不到这个属性,这样就造成了一定的性能浪费,另外一点则是非常容易忽视的地方在于他的优先级,也是我们说的特指度,通用选择器的特指度为0,结合上面的继承来说,继承是没有特指度的,因此你如果用了通用选择符,然后指望元素通过继承获得父元素的继承属性,却会发现不起作用。来看个

* {
  color: green;
}
div#page {
  color: black;
}
<div id="page">
  我是CSS世界的小<em>菜鸡</em>
</div>

很明显,最终看到的菜鸡是绿色的。因此这也是非常容易让人困惑的地方,所以推荐是尽量不要过度使用

盒模型

块级盒子

我们都知道BFC、IFC这样的名词,也知道他们的定义,比如BFC,就是块级格式化上下文,表示块级盒子定义的区域,拥有自己的渲染规则,并且盒子之间不会相互影响等。但是具体包含了哪些渲染规则以及如何渲染可能知道的比较模糊,这里也是说下容易忽略的地方。

在说这些渲染规则之前,先来说下一些概念,理解了这些概念,才能更好的理解盒模型。

  • 块级框,div 等块级元素生成的框体就是块级框
  • 行内框,同理,span 这样的行内元素生成的框体就是行内框
  • 行内块级框,即 display: inline-block的行内块级元素生成的框体就是行内块级框。
  • 容纳快,就是包含当前元素的父级框体,简单来说,块级元素的容纳块就是块级框,行内元素的容纳块就是行内框,当然也有可能是块级框。

而BFC、IFC这样的格式化上下文就是在容纳块中定义的。先从横向布局开始说起,看下面的

.line8 > .child1 {
  width: auto;
  margin-left: 50px;
  margin-right: 20px;
}
.line8 > .child2 {
  width: 300px;
  margin-left: auto;
  margin-right: 150px;
}
.line8 > .child3 {
  width: 300px;
  margin-left: auto;
  margin-right: auto;
}
.line8 > .child4 {
  width: 300px;
  margin-left: auto;
  margin-right: -200px;
}

得到的结果如下:

从中也不难看出:

  1. 横向布局时,外边距不会发生折叠
  2. 包含一个auto值时,用整个容纳块的宽度减去设置的宽度,剩下的宽度分配给设置给auto的元素,因为外边距可以是负值,因此对于负值而言,也同样适用上述规则,可以看到第四个div就是负值外边距的情况。
  3. 包含两个auto值时,就是将剩余距离平分为两份,每个auto值各占一半,这也是我们平时经常使用margin: 0 auto;居中的原理是一样的。

需要注意的时,这里关于块级盒子的一些属性,如外边距,内边距,边框,轮廓等,除了外边距可以设置为负值,其他设置为负值的时候,浏览器会忽略掉整条规则,并且auto值也只有宽高、外边距以及轮廓属性可以设置,其他设置auto值都是无效的,会被浏览器忽略掉。

再说纵向布局会产生margin折叠,折叠的规则就是取大值,也就是对于两个纵向布局的元素,margin-bottom和margin-top发生重叠,那么谁的值大就取谁的值作为折叠后的外边距的值。如果margin为负值的话,则取其绝对值大的那个值为折叠后的边距,如下所示:

.line8 > .child5 {
  margin-bottom: 10px;
}
.line8 > .child6 {
  margin-top: -50px;
}


行内盒子

行内元素分为两个,一个是非置换元素,一个是置换元素。这两个元素在布局上也是有所不同的。

老规矩,先来说些概念:

  • 匿名文本,就是不包含标签的文本,比如之前例子中我们给 span 元素前面加上了x-height这样的文本就是匿名文本。
  • 字体框,顾名思义,就是font-size属性决定的字体占据的框
  • 行距,就是line-height属性设置的值减去font-size的值就是行高,除以2分配和字体上下两端,则是半行距。
  • 行内框,就是行距加上内容区,也就是字体文本的区域,对行内非置换元素来说,就是line-height设置的值,对于置换元素来说,就是他的内容区。
  • 行框,经过一行内所有的行内框的最高点到一行内行内框的最低点之间的距离。

下面是他的示意图

  1. 非置换元素 结合上面的概念,来看个
.line10 {
  border: 1px solid red;
}
.line10 > p {
  font-size: 12px;
  line-height: 12px;
}
.line10 > p::first-line {
  border: 1px solid #ccc;
  background: #f2f2f2;
}
.line10 > p > strong {
  font-size: 24px;
}

得到如下的显示:

可以看出来,加粗文本那段明显超出了内容区,即便如此,文本也都还是默认对齐的,下面改变一下强调文本,添加一些样式:

.line10 > p > em {
  padding: 20px;
}
.line10 > p > em {
  border: 20px solid blue;
}
.line10 > p > em {
  margin: 20px;
}



这里 1 像素的蓝色边框是为了能够看清强调文本所占据的范围,通过这几个结果对比,我们能看到,对于行内元素来说,无论是padding、border、还是margin对于行框来说完全没有影响,也就是纵向距离保持不变,不过文本的左右还是会产生了间距,同理对于负margin来说,行框大小依然不变,不过左右会产生重叠。

那么既然行内元素纵向布局不受这些组成盒模型的属性所影响,那么到底什么属性影响行框大小呢,试试这个属性:

.line10 > p > strong {
  font-size: 24px;
  vertical-align: 4px;
}

可以看到行框的高度比之前多出了4px,这也就是说vertical-align会影响到纵向布局。在前一部分的时候说过,vertical-align计算是会受到line-height影响的,并且对于下面说到的置换元素而言,line-height就是置换元素的内容区,所以我们知道,影响行内元素纵向布局的主要属性就是这两个了。

  1. 置换元素 置换元素的布局则又不同了,还是看个
.line11 {
  font-size: 15px;
  line-height: 18px;
  border: 1px solid red;
}
.line11 > img {
  height: 30px;
  /* margin: 20px; */
  /* border: 0; */
  /* padding: 0; */
}


展示的结果其实和我们上面介绍图片间隙的例子是一样的,现在来看看对布局的影响,上面注释的三个属性,一个一个尝试一下,会发现都会对行内框的高度有影响,这是和非置换元素完全不同的表现。这里就不展示具体的结果了,可以自己去尝试看看。

  1. 行内块级元素 这里将行内块级元素放在这里是因为行内块级元素可以看做是置换元素,因此他们的布局影响是一样的,盒模型的属性都会对上下左右产生影响,因此不再赘述。



原文链接:https://juejin.im/post/6866789805615742989

相信做过网页的对Css都不是很陌生,它可以帮助我们重铸网页中很多绚丽的特效,尤其是现在Css已经发展3.0版本,很多功能更是丰富多彩,让我们的开发时间不仅大大缩短,而且还可以轻松做出许多华丽的特效,需要注意的是,Css相当于Html的一个美化装置,所以它必须依赖于Html才能发挥作用,那么今天我们就来深入了解下它吧。

一、Css的用法

1.如何使用Css

要想使用Css来增加Html的美观,有三种方式:

1).头部文件中定义

<style>
    标签的Css属性
</style>

2).导入Css文件

创建一个Css文件,里面写入样式,然后导入
<link rel="stylesheet" type="text/Css" href="1.Css">

3).直接在标签中定义

<div style='width:120px;height:60px;background-color:red'></div>Css注释
注:与Html 不同,它的注释方式是:/* Css语句*/

2.Css的选择器

为什么一开始要讲选择器了,因为我们要想精确修改的Html中的某个元素的属性,就必须使用选择器,它可以通过选择器定位到某个元素上然后修改元素的样式。

1).id和class选择器

id选择器必须现在标签中的定义,然后在在头部标签的style标签中用“#”来表示:

<Html>
<head>
  <title>Css应用</title>
  <style type="text/Css"> 
     #dv{
       background: red 更改div的背景颜色为红色
     }
</style>
</head>
<body>
<div id='dv'>fd</div> 定义一个id为dv的div
</body>
</Html>

class选择器和id选择器差不多,只不过class选择器用”.“来表示:

<Html>
<head>
  <title>Css应用</title>
  <style type="text/Css">
     .dv{
       background: red
     }
</style>
</head>
<body>
<div class='dv'>fd</div>
</body>
</Html>

2).元素选择器

就是指直接声明标签名为选择器,然后更改样式

<Html>
<head>
  <title>Css应用</title>
  <style type="text/Css">
     div{
       background: red
     }
</style>
</head>
<body>
<div>fd</div>
</body>
</Html>

或者声明所有标签名为选择器

<Html>
<head>
  <title>Css应用</title>
  <style type="text/Css">
    Html,head,body,div{
       background: red
     }
</style>
</head>
<body>
<div>fd</div>
</body>
</Html>

也可以使用元素加选择器更加精确的定位到该元素

<Html>
<head>
  <title>Css应用</title>
  <style type="text/Css">
   div#er{
       background: red
     }
</style>
</head>
<body>
<div id='df'>fd</div>
<p>fhsjak</p>
<div id='er'>re</div>
</body>
</Html>

3).后代选择器

访问一个元素内的其它元素,可以是元素内的任意元素

<Html>
<head>
  <title>Css应用</title>
  <style type="text/Css">
     div span{
       background: red
     }
</style>
</head>
<body>
<div>
<p>erzi
<span>sunzi</span>
</p>
</div>
</body>
</Html>

4).子元素选择器

<Html>
<head>
  <title>Css应用</title>
  <style type="text/Css">
     div>p{
       background: red
     }
</style>
</head>
<body>
<div>
<p>erzi
<span>sunzi</span>
</p>
</div>
</body>
</Html>

5).兄弟选择器

位于元素的下一个元素,不在元素内

<Html>
<head>
  <title>Css应用</title>
  <style type="text/Css">
     div+big{
       background: red
     }
</style>
</head>
<body>
<div>
<p>erzi
<span>sunzi</span>
</p>
</div>
<big>borther</big>
</body>
</Html>

6).伪类选择器

伪类选择器可分为三类

1)).锚伪类,用于检测鼠标的悬停状态。

<Html>
<head>
  <title>Css应用</title>
  <style type="text/Css">
     a:link{    /* 未访问的链接 */
       background: red
     }
     a:visited{    /* 已访问的链接 */
      background: green
     }
     a:hover{  /* 鼠标移动到链接上 */
      background: blue
     }
     a:active{  /* 选定的链接 */
      background: yellow
     }
</style>
</head>
<body>
<a href="https://www.baidu.com">百度</a>
</body>
</Html>

注:a:hover必须置于a:link和a:visited 之后,才是有效的。a:active必须被置于a:hover 之后,才是有效的。

2)). :first-child伪类

匹配第一个匹配到的标签

<Html>
<head>
  <title>Css应用</title>
  <style type="text/Css">
     p:first-child{  匹配第一个p标签
       background: red
     }
     div:first-child{ 匹配第一个div标签
      background: blue
     }
</style>
</head>
<body>
<div id='dv'>
<p class='fd'>fdaf
<div id='gfd'>grerg</div>
</p>
<div class='gf'>fsdjkfhkj
<a href="https://www.baidu.com">baidu</a>
</div>
</div>
</body>
</Html>

3)). :lang伪类

<Html>
<head>
  <title>Css应用</title>
  <style type="text/Css">
  q:lang(hw)  短引用利用伪类
   {
   quotes: "^" "^"
   }
</style>
</head>
<body>
<div id='dv'>
<p>hw<q lang="hw">任性的90后boy</q></p> 必须要用短引用
</div>
</body>
</Html>
<Html>
<head>

总结

这篇文章主要讲述了CSS的基础用法,讲述了如何定义头文件,导入CSS文件,id和class选择器,元素选择器,后代选择器,子元素选择器,兄弟选择器,伪类选择器等等,希望让大家对CSS选择器有个简单的认识和了解。

****看完本文有收获?请转发分享给更多的人****

IT共享之家

入群请在微信后台回复【入群】

想要学习更多,请前往Python爬虫与数据挖掘专用网站:http://pdcfighting.com/

ss进阶

原文出处>>>

https://blog.csdn.net/u014158743/article/details/136240947

01-复合选择器

定义:由两个或多个基础选择器,通过不同的方式组合而成。

作用:更准确、更高效的选择目标元素(标签)。

后代选择器

后代选择器:选中某元素的后代元素

选择器写法:父选择器 子选择器 { CSS 属性},父子选择器之间用空格隔开。

<style>
  div span {
    color: red;
  }
</style>
<span> span 标签</span>
<div>
  <span>这是 div 的儿子 span</span >
</div>

子代选择器

子代选择器:选中某元素的子代元素(最近的子级)。

选择器写法:父选择器 > 子选择器 { CSS 属性},父子选择器之间用 > 隔开。

<style>
  div > span {
    color: red;
  }
</style>

<div>
  <span>这是 div 里面的 span</span>
  <p>
    <span>这是 div 里面的 p 里面的 span</span>
  </p>
</div>

并集选择器

并集选择器:选中多组标签设置相同的样式。

选择器写法:选择器1, 选择器2, …, 选择器N { CSS 属性},选择器之间用 , 隔开。

<style>
  div,
  p,
  span {
    color: red;
  }
</style>

<div> div 标签</div>
<p>p 标签</p>
<span>span 标签</span>

交集选择器

交集选择器:选中同时满足多个条件的元素。

选择器写法:选择器1选择器2 { CSS 属性},选择器之间连写,没有任何符号。

<style>
  p.box {
  color: red;
}
</style>

<p class="box">p 标签,使用了类选择器 box</p>
<p>p 标签</p>
<div class="box">div 标签,使用了类选择器 box</div>

注意:如果交集选择器中有标签选择器,标签选择器必须书写在最前面。

伪类选择器

伪类选择器:伪类表示元素状态,选中元素的某个状态设置样式。

鼠标悬停状态:选择器:hover { CSS 属性 }

<style>
  a:hover {
    color: red;
  }
 .box:hover {
    color: green;
  }
</style>

<a href="#">a 标签</a>
<div class="box">div 标签</div>

超链接伪类

选择器作用:link选择尚未被访问的超链接。:visited选择已被访问过的超链接。:hover鼠标悬停在超链接上时应用的样式。:active超链接被点击时应用的样式,通常用于短暂的样式变化,以示被点击。:focus超链接获取焦点时应用的样式,通常用于键盘导航时给予用户视觉反馈。

提示:如果要给超链接设置以上四个状态,需要按 LVHA 的顺序书写。

经验:工作中,一个 a 标签选择器设置超链接的样式, hover状态特殊设置

a {
 color: red;
}

a:hover {
 color: green;
}

02-CSS特性

CSS特性:化简代码 / 定位问题,并解决问题

  • 继承性

  • 层叠性

  • 优先级

继承性

继承性:子级默认继承父级的文字控制属性

描述属性效果设置文字大小font-size控制文字的大小。设置文字样式font-style控制文字的样式,如斜体(italic)或正常(normal)。设置行高line-height控制行与行之间的距离,实现单行文字的垂直居中。设置字体族font-family指定用于显示文本的字体系列,可以是单个字体名称或一系列备选字体。设置文字对齐方式text-align控制文本在盒子中的水平对齐方式,如左对齐、右对齐、居中等。设置文本缩进text-indent控制段落的首行缩进。设置文本修饰线text-decoration添加文本的修饰线,如下划线、删除线等。设置文字颜色color控制文本的颜色。

层叠性

特点:

  • 相同的属性会覆盖:后面的 CSS 属性覆盖前面的 CSS 属性

  • 不同的属性会叠加:不同的 CSS 属性都生效

<style>
  div {
    color: red;
   font-weight: 700;
  }
  div {
    color: green;
    font-size: 30px;
  }
</style>

<div>div 标签</div>

注意:选择器类型相同则遵循层叠性,否则按选择器优先级判断。

尝试一下>>>

优先级

优先级:也叫权重,当一个标签使用了多种选择器时,基于不同种类的选择器的匹配规则

<style>
  div {
    color: red;
  }
  .box {
    color: green;
  }
</style>

<div class="box">div 标签</div>

基础选择器

规则:选择器优先级高的样式生效

公式:通配符选择器 < 标签选择器 < 类选择器 < id选择器 < 行内样式 < !important

(选中标签的范围越大,优先级越低)

复合选择器-叠加

叠加计算:如果是复合选择器,则需要权重叠加计算。

公式:(每一级之间不存在进位)

(行内样式,id选择器个数,选择器个数,标签选择器个数)

规则:

  • 从左向右依次比较选个数,同一级个数多的优先级高,如果个数相同,则向后比较

  • !important 权重最高

  • 继承权重最低

练习:

<!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>
   /* (0, 0, 2, 1) */
   .c1 .c2 div {
  color: blue;
 }
 
   /* (0, 1, 0, 1) */
 div #box3 {
  color:green;
 }
 
   /* (0, 1, 1, 0) */
 #box1 .c3 {
  color:orange;
 }
 </style>
</head>
<body>
 <div id="box1" class="c1">
 <div id="box2" class="c2">
  <div id="box3" class="c3">
   这行文本是什么颜色的?
  </div>
 </div>
</div>
</body>
</html>

尝试一下>>>

03-Emmet 写法

Emmet写法:代码的简写方式,输入缩写 VS Code 会自动生成对应的代码。

以下是关于HTML标签的Emmet写法的表格:

说明标签结构Emmet写法创建一个div标签<div></div>div创建一个带有class的div标签<div></div>div.classname创建一个带有id的div标签<div id="idname"></div>div#idname创建一个段落标签<p></p>p创建一个带有文本内容的段落标签<p>Text</p>p{Text}创建一个带有链接的标签<a href="#"></a>a[href="#"]创建一个列表项标签<li></li>li创建一个无序列表标签<ul></ul>ul创建一个有序列表标签<ol></ol>ol创建一个图片标签<img src="" alt="">img[src=""][alt=""]

这些Emmet写法可以帮助快速生成HTML标签结构。

以下是关于CSS的Emmet写法的表格:

说明CSS结构Emmet写法创建一个带有class的样式表<link rel="stylesheet" href="style.css">link:css创建一个内联样式表<style></style>style创建一个选择器为.classname的样式规则.classname {}.classname创建一个选择器为#idname的样式规则#idname {}#idname创建一个选择器为tagname的样式规则tagname {}tagname向选择器为.classname的样式规则中添加属性.classname { property: value; }.classname { property: value; }向选择器为#idname的样式规则中添加属性#idname { property: value; }#idname { property: value; }向选择器为tagname的样式规则中添加属性tagname { property: value; }tagname { property: value; }

这些Emmet写法可以帮助快速编写CSS样式规则。

04-背景属性

背景图

网页中,使用背景图实现装饰性的图片效果。

  • 属性名:background-image(bgi)

  • 属性值:url(背景图 URL)

div {
  width: 400px;
  height: 400px;

  background-image: url(./images/1.png);
}

提示:背景图默认有平铺(复制)效果

平铺方式

属性名:background-repeat(bgr)

属性值效果repeat默认值,背景图像在水平和垂直方向上重复。repeat-x背景图像在水平方向上重复,垂直方向不重复。repeat-y背景图像在垂直方向上重复,水平方向不重复。no-repeat背景图像不重复,仅在盒子内显示一次。space背景图像沿着盒子的边缘平铺,且图像之间有空白间隔,使得图片不会重叠。round背景图像沿着盒子的边缘平铺,且图像会被缩放以适应整数倍的尺寸。

div {
  width: 400px;
  height: 400px;
  background-color: pink;
  background-image: url(./images/1.png);

  background-repeat: no-repeat;
}

背景图位置

属性名:background-position(bgp)

属性值:水平方向位置 垂直方向位置

  • 关键字

以下是关于背景图位置的关键字的表格:

关键字位置top图片顶部对齐bottom图片底部对齐left图片左侧对齐right图片右侧对齐center图片居中对齐top left图片左上角对齐top right图片右上角对齐bottom left图片左下角对齐bottom right图片右下角对齐

这些关键字可以帮助你控制背景图在元素中的位置。

  • 坐标

    • 水平:正数向右;负数向左

    • 垂直:正数向下;负数向上

div {
  width: 400px;
  height: 400px;
  background-color: pink;
  background-image: url(./images/1.png);
  background-repeat: no-repeat;

  background-position: center bottom;
  background-position: 50px -100px;
 background-position: 50px center;
}

提示:

  • 关键字取值方式写法,可以颠倒取值顺序

  • 可以只写一个关键字,另一个方向默认为居中;数字只写一个值表示水平方向,垂直方向为居中

背景图缩放

作用:设置背景图大小

属性名:background-size(bgz)

常用属性值:

  • 关键字

    • cover:等比例缩放背景图片以完全覆盖背景区,可能背景图片部分看不见

    • contain:等比例缩放背景图片以完全装入背景区,可能背景区部分空白

  • 百分比:根据盒子尺寸计算图片大小

  • 数字 + 单位(例如:px)

div {
  width: 500px;
  height: 400px;
  background-color: pink;
  background-image: url(./images/1.png);
  background-repeat: no-repeat;
 
  background-size: cover;
  background-size: contain;
}

提示:工作中,图片比例与盒子比例相同,使用 cover 或 contain 缩放背景图效果相同。

背景图固定

作用:背景不会随着元素的内容滚动。

属性名:background-attachment(bga)

属性值:fixed

body {
  background-image: url(./images/bg.jpg);
  background-repeat: no-repeat;
  background-attachment: fixed;
}

背景复合属性

属性名:background(bg)

属性值:背景色 背景图 背景图平铺方式 背景图位置/背景图缩放 背景图固定(空格隔开各个属性值,不区分顺序

div {
  width: 400px;
  height: 400px;

  background: pink url(./images/1.png) no-repeat right center/cover;
}

尝试一下>>>

05-显示模式

显示模式:标签(元素)的显示方式。

作用:布局网页的时候,根据标签的显示模式选择合适的标签摆放内容。

块级元素

特点:

  • 独占一行

  • 宽度默认是父级的100%

  • 添加宽高属性生效

行内元素

特点:

  • 一行可以显示多个

  • 设置宽高属性不生效

  • 宽高尺寸由内容撑开

行内块元素

特点:

  • 一行可以显示多个

  • 设置宽高属性生效

  • 宽高尺寸也可以由内容撑开

转换显示模式

属性:display

以下是关于转换显示模式的表格:

属性值效果block将元素显示为块级元素,使元素呈现为一个块,独占一行,可以设置宽度和高度,可容纳其他元素。inline将元素显示为内联元素,使元素呈现为行内元素,不独占一行,只占据内容所需的空间,不可设置宽高。inline-block将元素显示为内联块元素,元素呈现为行内元素但可以设置宽度和高度,与其他行内元素在一行显示。none隐藏元素,使元素不可见且不占据空间。flex将元素设置为弹性容器,使其子元素成为弹性项目,可利用弹性布局方式控制元素的排列和对齐方式。grid将元素设置为网格容器,使其子元素成为网格项目,可利用网格布局方式控制元素的排列和对齐方式。inline-flex将元素设置为内联弹性容器,使其子元素成为弹性项目,可利用弹性布局方式控制元素的排列和对齐方式。inline-grid将元素设置为内联网格容器,使其子元素成为网格项目,可利用网格布局方式控制元素的排列和对齐方式。

这些属性值可用于控制元素的显示模式,从而实现不同的布局效果。