CSS基础知识day2

目录

1.Emmet 语法

1.1 快速生成HTML结构语法

1.2 快速生成CSS样式语法

2.CSS 的复合选择器

2.1 什么是复合选择器

2.1.1 后代选择器

2.1.2 子选择器

2.1.3 并集选择器

2.1.4 伪类选择器

2.1.5 :focus 伪类选择器

2.2 复合选择器总结

3.CSS 的元素显示模式

3.1 什么是元素显示模式

3.2 元素显示模式的分类

3.2.1 块元素

3.2.2 行内元素

3.2.3 行内块元素

3.3 元素显示模式总结

3.4 元素显示模式转换

3.5 如何单行文字垂直居中的代码

4.CSS 的背景

4.1 背景颜色

4.2 背景图片

4.3 背景平铺

4.4 背景图片位置

4.5 背景图像固定(背景附着)

4.6 背景复合写法

4.7 背景色半透明

4.8 背景总结

5.综合案例


1.Emmet 语法

Emmet语法的前身是Zen coding,它使用缩写,来提高html/css的编写速度,Vscode内部已经集成该语法。
作用:
  • 1. 快速生成HTML结构语法
  • 2. 快速生成CSS样式语法

1.1 快速生成HTML结构语法

  • 1.生成标签 直接输入标签名 按tab键即可 比如 div 然后tab 键, 就可以生成 <div></div>
  • 2. 如果想要生成多个相同标签 加上 * 就可以了 比如 div*3 就可以快速生成3个div
  • 3. 如果有父子级关系的标签,可以用 > 比如 ul > li就可以了
  • 4. 如果有兄弟关系的标签,用 + 就可以了 比如 div+p
  • 5. 如果生成带有类名或者id名字的, 直接写 .demo 或者 #two tab 键就可以了
  • 6. 如果生成的div 类名是有顺序的, 可以用 自增符号 $
  • 7. 如果想要在生成的标签内部写内容可以用 { } 表示

1.2 快速生成CSS样式语法

CSS 基本采取简写形式即可。
1. 比如 w200 按tab 可以 生成 width: 200px;
2. 比如 lh26px 按tab 可以生成 line-height: 26px;

2.CSS 的复合选择器

2.1 什么是复合选择器

在 CSS 中,可以根据选择器的类型把选择器分为 基础选择器 复合选择器 ,复合选择器是建立在基础选择器之上,对 基本选择器进行组合形成的。
  • 复合选择器可以更准确、更高效的选择目标元素(标签)
  • 复合选择器是由两个或多个基础选择器,通过不同的方式组合而成的
  • 常用的复合选择器包括:后代选择器、子选择器、并集选择器、伪类选择器等等

2.1.1 后代选择器

后代选择器 又称为 包含选择器 ,可以选择父元素里面子元素。其写法就是把外层标签写在前面,内层标签写在 后面,中间用空格分隔。当标签发生嵌套时,内层标签就成为外层标签的后代。
语法:

上述语法表示 选择元素 1 里面的所有元素 2 (后代元素)。

例如:

注意事项:

  • 元素1 和 元素2 中间用空格隔开
  • 元素1 是父级,元素2 是子级,最终选择的是元素2
  • 元素2 可以是儿子,也可以是孙子等,只要是元素1 的后代即可
  • 元素1 和 元素2 可以是任意基础选择器

2.1.2 子选择器

子元素选择器(子选择器) 只能选择作为某元素的最近一级子元素。简单理解就是选亲儿子元素。
语法:
上述语法表示 选择元素1 里面的所有直接后代(子元素) 元素2
例如:
注意事项:
  • 元素1 和 元素2 中间用 大于号 隔开
  • 元素1 是父级,元素2 是子级,最终选择的是元素2
  • 元素2 必须是亲儿子,其孙子、重孙之类都不归他管. 你也可以叫他 亲儿子选择器

问答环节:
 

1. 请将下面的 链接文字 修改为红色。
2. 请将下面的 大肘子 文字修改为红色。

2.1.3 并集选择器

并集选择器可以选择多组标签, 同时为他们定义相同的样式 。通常用于集体声明。
并集选择器 是各选择器 通过英文逗号(,)连接而成 任何形式的选择器都可以作为并集选择器的一部分。
语法:
上述语法表示 选择元素1 和 元素2
例如:
注意事项:
  • 元素1 和 元素2 中间用逗号隔开
  • 逗号可以理解为的意思
  • 并集选择器通常用于集体声明

2.1.4 伪类选择器

伪类选择器 用于向某些选择器添加特殊的效果,比如给链接添加特殊效果。
伪类选择器书写最大的特点是 用冒号(:)表示 ,比如 :hover 、 :first-child 。
因为伪类选择器很多,比如有链接伪类、结构伪类等
链接伪类选择器
链接伪类选择器注意事项
  • 1. 为了确保生效,请按照 LVHA 的循顺序声明 :link        -:visited-:hover-:active。
  • 2. 因为 a 链接在浏览器中具有默认样式,所以我们实际工作中都需要给链接单独指定样式

链接伪类选择器实际工作开发中的写法

2.1.5 :focus 伪类选择器

:focus 伪类选择器 用于选取获得焦点的表单元素。
焦点就是光标,一般情况 <input> 类表单元素才能获取,因此这个选择器也主要针对于表单元素来说。

2.2 复合选择器总结

3.CSS 的元素显示模式

3.1 什么是元素显示模式

作用:网页的标签非常多,在不同地方会用到不同类型的标签,了解他们的特点 可以更好的布局我们的网页
元素显示模式就是 元素(标签)以什么方式进行显示 ,比如<div>自己占一行,比如一行可以放多个<span>。
HTML 元素一般分为 块元素 行内元素 两种类型。

3.2 元素显示模式的分类

3.2.1 块元素

常见的块元素有<h1>~<h6>、<p>、<div>、<ul>、<ol>、<li>等,其中 <div> 标签是 最典型的块元素
块级元素的特点:
  • ① 比较霸道,自己独占一行。
  • ② 高度,宽度、外边距以及内边距都可以控制。
  • ③ 宽度默认是容器(父级宽度)的100%。
  • ④ 是一个容器及盒子,里面可以放行内或者块级元素。
注意:
  • 文字类的元素内不能使用块级元素
  • <p> 标签主要用于存放文字,因此 <p> 里面不能放块级元素,特别是不能放<div>
  • 同理, <h1>~<h6>等都是文字类块级标签,里面也不能放其他块级元素

3.2.2 行内元素

常见的行内元素有 <a>、<strong>、<b>、<em>、<i>、<del>、<s>、<ins>、<u>、<span>等,其中 <span> 标签是 最典型的行内元素 。有的地方也将行内元素称为 内联元素
行内元素的特点:
  • ① 相邻行内元素在一行上,一行可以显示多个。
  • ② 高、宽直接设置是无效的。
  • ③ 默认宽度就是它本身内容的宽度。
  • ④ 行内元素只能容纳文本或其他行内元素。
注意:
  • 链接里面不能再放链接
  • 特殊情况链接 <a> 里面可以放块级元素,但是给 <a> 转换一下块级模式最安全

3.2.3 行内块元素

在行内元素中有几个特殊的标签 —— <img />、<input />、<td>,它们 同时具有块元素和行内元素的特点 。 有些资料称它们为 行内块元素
行内块元素的特点:
  • ① 和相邻行内元素(行内块)在一行上,但是他们之间会有空白缝隙。一行可以显示多个(行内元素特点)。
  • ② 默认宽度就是它本身内容的宽度(行内元素特点)。
  • ③ 高度,行高、外边距以及内边距都可以控制(块级元素特点)

3.3 元素显示模式总结

学习元素显示模式的主要目的就是分清它们各自的特点,当我们网页布局的时候,在合适的地方用合适的标签元素。

3.4 元素显示模式转换

特殊情况下,我们需要元素模式的转换,简单理解: 一个模式的元素需要另外一种模式的特性
比如想要增加链接 <a> 的触发范围。
  • 转换为块元素:display:block;
  • 转换为行内元素:display:inline;
  • 转换为行内块:display: inline-block;

案例:
实现简洁版小米侧边栏
案例的核心思路分为两步:
1. 把链接a 转换为块级元素, 这样链接就可以单独占一行,并且有宽度和高度.
2. 鼠标经过a 给链接设置背景颜色
效果:
代码:
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        a {
            width: 230px;
            height: 40px;
            background-color: blanchedalmond;
            display: block;
            color: steelblue;
            text-decoration: none;
            text-indent: 2em;
            line-height: 40px;
        }

        a:hover {
            background-color: yellow;
        }
    </style>
</head>

<body>
    <a href="#">手机 电话卡</a>
    <a href="#">电视 盒子</a>
    <a href="#">笔记本 平板</a>
    <a href="#">出行 穿戴</a>
    <a href="#">智能 路由器</a>
    <a href="#">健康 儿童</a>
    <a href="#">耳机 音响</a>
</body>

</html>

3.5 如何单行文字垂直居中的代码

CSS 没有给我们提供文字垂直居中的代码. 这里我们可以使用一个小技巧来实现.
解决方案: 让文字的行高等于盒子的高度 就可以让文字在当前盒子内垂直居中
简单理解: 行高的上空隙和下空隙把文字挤到中间了. 是如果行高小于盒子高度,文字会偏上,如果行高大于盒子高度,则文字偏下

4.CSS 的背景

通过 CSS 背景属性,可以给页面元素添加背景样式。
背景属性可以设置 背景颜色、背景图片、背景平铺、背景图片位置、背景图像固定 等。

4.1 背景颜色

background-color 属性定义了元素的背景颜色。
语法:
一般情况下元素背景颜色默认值是 transparent (透明)。

4.2 背景图片

background-image 属性描述了元素的背景图像。实际开发常见于 logo 或者一些装饰性的小图片或者是超大的背景图片, 优点是非常便于控制位置. (精灵图也是一种运用场景)

语法:

注意:背景图片后面的地址,千万不要忘记加 URL, 同时里面的路径不需要加引号。

4.3 背景平铺

如果需要在 HTML 页面上对背景图像进行平铺,可以使用 background-repeat 属性。
默认平铺的效果
不平铺的效果
沿着x轴平铺的效果
沿着y轴平铺的效果

4.4 背景图片位置

利用 background-position 属性可以改变图片在背景中的位置。
参数代表的意思是:x 坐标和 y 坐标。 可以使用 方位名词 或者 精确单位
参数说明:
1. 参数是方位名词
  • 如果指定的两个值都是方位名词,则两个值前后顺序无关,比如 left top 和 top left 效果一致
  • 如果只指定了一个方位名词,另一个值省略,则第二个值默认居中对齐
2. 参数是精确单位
  • 如果参数值是精确坐标,那么第一个肯定是 x 坐标,第二个一定是 y 坐标
  • 如果只指定一个数值,那该数值一定是 x 坐标,另一个默认垂直居中
3. 参数是混合单位
  • 如果指定的两个值是精确单位和方位名词混合使用,则第一个值是 x 坐标,第二个值是 y 坐标

4.5 背景图像固定(背景附着)

background-attachment 属性设置背景图像是否固定或者随着页面的其余部分滚动。
background-attachment 后期可以制作视差滚动的效果。
默认值是scroll

4.6 背景复合写法

为了简化背景属性的代码,我们可以将这些属性合并简写在同一个属性 background 中。从而节约代码量。
当使用简写属性时,没有特定的书写顺序,一般习惯约定顺序为:
background: 背景颜色 背景图片地址 背景平铺 背景图像滚动 背景图片位置;
这是实际开发中,我们更提倡的写法。

4.7 背景色半透明

CSS3 为我们提供了背景颜色半透明的效果。

注意事项:

  • 最后一个参数是 alpha 透明度,取值范围在 0~1之间
  • 我们习惯把 0.3 的 0 省略掉,写为 background: rgba(0, 0, 0, .3);
  • 背景半透明是指盒子背景半透明,盒子里面的内容不受影响

4.8 背景总结

背景图片:实际开发常见于 logo 或者一些装饰性的小图片或者是超大的背景图片, 优点是非常便于控制位置。(精灵图也是一种运用场景)

5.综合案例

案例:五彩导航
练习价值:
1. 链接属于行内元素, 但是此时需要宽度高度,因此需要模式转换.
2. 里面文字需要水平居中和垂直居中. 因此需要单行文字垂直居中的代码.
3. 链接里面需要设置背景图片.因此需要用到背景的相关属性设置.
4. 鼠标经过变化背景图片,因此需要用到链接伪类选择器.

效果:

代码:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        a {
            display: inline-block;
            width: 120px;
            height: 58px;
            background-color: beige;
            text-decoration: none;
            color: red;
            line-height: 48px;
            text-align: center;
        }

        .nav .dm1 {
            background-image: url(./images/bg1.png);
        }

        .nav .dm1:hover {
            background-image: url(./images/bg11.png);
        }

        .nav .dm2 {
            background-image: url(./images/bg2.png);
        }

        .nav .dm2:hover {
            background-image: url(./images/bg22.png);
        }

        .nav .dm3 {
            background-image: url(./images/bg3.png);
        }

        .nav .dm3:hover {
            background-image: url(./images/bg33.png);
        }

        .nav .dm4 {
            background-image: url(./images/bg4.png);
        }

        .nav .dm4:hover {
            background-image: url(./images/bg44.png);
        }

        .nav .dm5 {
            background-image: url(./images/bg5.png);
        }

        .nav .dm5:hover {
            background-image: url(./images/bg55.png);
        }
    </style>
</head>

<body>
    <div class="nav">
        <a href="#" class="dm1">五彩导航</a>
        <a href="#" class="dm2">五彩导航</a>
        <a href="#" class="dm3">五彩导航</a>
        <a href="#" class="dm4">五彩导航</a>
        <a href="#" class="dm5">五彩导航</a>
    </div>



</body>

</html>

  • 11
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值