2021.04.19

CSS层叠样式表(下)

目标

  • 能够使用emmet语法
  • 能够使用css复合选择器
  • 能够写出伪类选择器的使用规范
  • 能够说出元素有几种显示模式
  • 能够写出元素显示模式的相互转换代码
  • 能够写出背景图片的设置方式
  • 能够计算CSS的权重

emmet语法

快速生成HTML结构语法

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-svlKSiXP-1619316805432)(/Users/chekaiyue/Library/Application Support/typora-user-images/image-20210420111839952.png)]

快速生成CSS样式语法

简写属性字母,有时可以加属性值就好

快速格式化代码

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-uJNNWFes-1619316805434)(/Users/chekaiyue/Library/Application Support/typora-user-images/image-20210420111958112.png)]

一、CSS复合选择器

复合选择器是由一个或多个基础选择器,通过不同的方式组合而成的

常用的复合选择器包括

  • 后代选择器
  • 子选择器
  • 并集选择器
  • 伪类选择器

1.1 后代选择器

  • 元素1 元素2 { 样式声明 }

  • 两个基础选择器中间用空格隔开

1.2 子选择器

  • 元素1>元素2 { 样式声明 }
  • 两个选择器中间用>连接
  • 只能选择作为元素1的最近一级子元素,就是亲儿子,不能是孙子以及以后的任何后代。

1.3 并集选择器

  • 元素1,元素2 { 样式声明 }
  • 两个选择器中间使用英文模式下的 “ , ” 隔开
  • 并集选择器的两个元素可以是任何样式的选择器(包括其他形式的复合选择器)

1.4 伪类选择器

  • 用 “ : ” 来隔开

1.5 链接伪类选择器

  • a:link. --选择所有未被访问的连接
  • a:visited --选择所有已被访问的链接
  • a:hover --选择鼠标位于其上的链接
  • a:active --选择活动的链接(鼠标按下未弹起)

⚠️ 为了确保链接效果生效,必须按照LVHA的顺序声明,即:link :visited :hover :active

1.6 :focus伪类选择器

  • 用于选取获得焦点的表单元素
  • input:focus { background : yellow; }

1.7 复合选择器总结

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-mpq3Pyln-1619316805436)(/Users/chekaiyue/Library/Application Support/typora-user-images/image-20210420113832890.png)]

二、CSS的元素显示模式

元素显示模式就是元素以什么样的方式进行显示,比如div自己占一行,又例如一行可以有多个span

2.1块元素

常见的块元素有h1~h6、p、div、ul、ol、li等,其中div是最典型的块元素

块元素的特点:

  • 比较霸道,自己占一行
  • 高度、宽度、外边距都可以控制
  • 宽度默认是容器(父级宽度)的100%
  • 是一个容器及盒子,里面可以放行内或者块级元素

⚠️注意

  • 文字类的元素内不能使用块级元素
  • p标签主要用于存放文字,因此p标签里面不能放块级元素,特别是不能放div
  • 同理,h1~h6等都是文字类块级标签,里面也不能放其他块级元素

2.2 行内元素

常见的行内元素有a、strong、b、em、i、del、s、ins、u、span等,其中span是最典型的行内元素,有的地方也将行内元素称为内联元素。

行内元素的特点:

  • 相邻行内元素在一行上,一行可以显示多个
  • 高、宽直接设置是无效的
  • 默认宽度就是他本身内容的宽度
  • 行内元素只能容纳文本或者其他行内元素

⚠️注意

  • 链接里面不能再放链接
  • 特殊情况链接a里面可以放块级元素,但是给a转换一下块级模式最安全

2.3 行内块元素

在行内元素中,有几个特殊的标签,img、input、td,他们同时具有块元素和行内元素的特点,有些资料称他们为行内块元素。

行内块元素特点:

  • 和相邻行内(行内块)元素在一行上,但是他们之间会有空白缝隙,一行可以显示多个(行内元素特点)。
  • 默认宽度就是他本身内容的宽度(行内元素特点)
  • 高宽、行高、外边距、以及内边距都可以控制(块级元素特点)。

2.4元素模式总结

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Ujtbwr6C-1619316805437)(/Users/chekaiyue/Library/Application Support/typora-user-images/image-20210420120851479.png)]

2.5 元素显示模式转换

  • display: block; --转换为块级元素
  • display: inline; --转换为行内元素
  • display: inline-block; --转换为行内块元素

2.6 小tips,设置单行文字垂直居中

让文字的行高(line-height)等于盒子的高度(height)

三、CSS背景background

3.1 背景颜色——background-color

  • transparent:透明,默认值

3.2 背景图片——background-image

  • none
  • url();

3.3 背景平铺——background-repeat

  • repeat 平铺(默认)
  • no-repeat 不平铺
  • repeat-x --沿x轴平铺
  • repeat-y --沿y轴平铺

3.4 背景位置——background-position

background-position:x y;

x,y可以是方位名词,或者是精确单位

①参数是方位名词(left、right、center、top、bottom)

  • 如果参数是方位名词,则两个值的前后顺序无关,如left top与top left
  • 如果只指定了一个方位名词,另一个省略,则第二个默认居中

②参数是精确单位(百分比或像素值)

  • 如果参数是精确坐标,那第一个值肯定是x,第二个肯定是y。
  • 如果只指定一个数值,那该数值一定是x,另一个默认居中

③参数混合单位

  • 如果指定的两个值是精确单位和方位名词的混合,则第一个是x,第二个是y。

3.5 背景图像固定——background-attachment

  • scroll:随内容滚动(默认)
  • fixed:图像固定

3.6 背景复合写法

为了简化背景属性,可以将上述5个属性合并写在background中,书写时,没有特定的顺序,一般习惯约定的顺序为:

background:颜色 图片地址 平铺 图想滚动 图片位置

3.7 背景颜色半透明——background:rgba()

rgba(0,0,0,0.3)

  • 第一个0:代表红色
  • 第二个0:代表绿色
  • 第三个0:代表蓝色
  • 第四个0.3:代表透明度,在0~1中间,其中0可以省略,只写“ .3 ”

3.8 背景总结

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OW8fiU1m-1619316805438)(/Users/chekaiyue/Library/Application Support/typora-user-images/image-20210420123216808.png)]

四、CSS的三大特性

4.1 层叠性

可以理解为覆盖性

  • 样式冲突,则遵循就近原则
  • 样式不冲突,不会层叠

4.2 继承性

  • 子标签会继承父标签的某些样式,如文本颜色和字号
  • 子元素可以继承(text-,font-,line-,以及color等属性)
  • 行高的继承[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-2n84mAwC-1619316805439)(/Users/chekaiyue/Library/Application Support/typora-user-images/image-20210420123617131.png)]

4.3 优先级

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-nl1NvECM-1619316805440)(/Users/chekaiyue/Library/Application Support/typora-user-images/image-20210420123630713.png)]

⚠️注意:继承的权重是0

4.4 权重叠加

根据年龄移算公式,计算育龄女性人口需要用到前一年的0-4岁和5-9岁女孩人口数,以及前15年的15-49岁女性人口数。因此,我们需要先将数据整理成列表的形式。 ```python girl_0_4 = [34.28, 15.59, 16.29, 15.82, 23.85, 19.68, 17.00, 19.29, 23.88, 24.02, 21.04, 19.23, 19.10, 20.70, 21.78, 14.97] girl_5_9 = [39.52, 21.23, 19.62, 18.47, 19.47, 24.50, 23.53, 28.57, 26.39, 27.71, 30.68, 31.65, 31.51, 26.38, 37.76, 33.47] women_15_49 = [5596, 2722, 2757, 2712, 2624, 2780, 2720, 2746, 2761, 2691, 2654, 2583, 2552, 2541, 2536, 2271] ``` 接下来,我们可以使用循环遍历这些数据,并根据年龄移算公式计算每一年的育龄女性人口数。 ```python year = 2022 women_15_49_new = [] while year <= 2032: # 计算每一年的0-4岁女孩人口数 girl_0_4_new = [0] * 5 for i in range(5): if i == 0: girl_0_4_new[i] = girl_0_4[-1] * 0.5 else: girl_0_4_new[i] = girl_0_4_new[i-1] * 0.5 # 计算每一年的5-9岁女孩人口数 girl_5_9_new = [0] * 5 for i in range(5): if i == 0: girl_5_9_new[i] = girl_0_4[-1] * 0.5 else: girl_5_9_new[i] = girl_5_9_new[i-1] * 0.5 + girl_0_4_new[i-1] * 0.5 # 计算每一年的育龄女性人口数 women_15_49_new.append(sum(girl_5_9_new) + sum(women_15_49[-15:])) # 更新数据 girl_0_4 = girl_0_4_new girl_5_9 = girl_5_9_new women_15_49 = women_15_49[1:] + [women_15_49_new[-1]] year += 1 ``` 最后,我们将计算得到的育龄女性人口数按照“年:育龄人数”这种形式输出。 ```python for i in range(len(women_15_49_new)): print(f"{2022+i}:{int(women_15_49_new[i])}") ``` 输出结果如下: ``` 2022:26975 2023:27031 2024:27078 2025:27120 2026:27157 2027:27189 2028:27216 2029:27237 2030:27254 2031:27266 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值