【前端】网页开发精讲与实战 CSS Day 2

🚀Write In Front🚀
📝个人主页:令夏二十三
🎁欢迎各位→点赞👍 + 收藏⭐️ + 留言📝
📣系列专栏:前端
💬总结:希望你看完之后,能对你有所帮助,不足请指正!共同学习交流 🖊

文章目录


前言

        今天是学习网页开发课程CSS基础的第二天,要学习的内容包括复合选择器、CSS特性、背景属性和显示模式。

一、复合选择器

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

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

1. 后代选择器

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

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

<!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>/* 后代选择器:选中所有后代,包含儿子、孙子、重孙子... */div p{color: blue;}</style>
</head>
<body><span>span 标签</span><div><span>这是div的儿子span</span><p><span>孙子 span</span></p></div>
</body>
</html>

 2. 子代选择器

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

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

<!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>/* div的儿子span文字颜色是红色 */div>span{color: deeppink;}</style>
</head>
<body><div><span>儿子 span</span><p><span>孙子 span</span></p></div>
</body>
</html>

 3. 并集选择器

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

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

<!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>div,p,span{color: red;}</style>
</head>
<body><div>div 标签</div><p>p 标签</p><span>span 标签</span>
</body>
</html>

 4. 交集选择器

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

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

<!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>p.box{color: red;}</style>
</head>
<body><p class="box">p 标签,使用了类选择器 box</p><p>p 标签</p><div class="box">div 标签,使用了类选择器 box</div>
</body>
</html>

 5. 伪类选择器

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

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

<!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>/* 任何标签都可以设置鼠标悬停的状态 */a:hover{color: red;}.box:hover{color: green;}</style>
</head>
<body><a href="#">a 标签,超链接</a><div class="box">div 标签</div>
</body>
</html>

 超链接一共有四个状态:

选择器作用
:link访问前
:visited访问后
:hover鼠标悬停
:active点击时(激活)

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

<!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>a:link{color:red;}a:visited{color:blue;}a:hover{color:green;}a:active{color: brown;}</style>
</head>
<body><a href="#">a 标签,测试伪类</a>
</body>
</html>

 二、CSS特性

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

1. 继承性

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

<!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>CSS特性-继承性</title><style>body{font-size: 30px;color: red;font-weight: 700;}</style>
</head>
<body><div>div 标签</div><p>p 标签</p><span>span 标签</span><!-- 如果标签自己有样式则生效自己的样式,不继承 --><a href="#">a 标签</a><h1>h1 标签</h1>
</body>
</html>

 2. 层叠性

特点:

  • 相同的属性会覆盖后面的CSS属性覆盖前面的CSS属性
  • 不同的属性会叠加:不同的CSS属性都生效

3. 优先级

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

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

公式:通配符选择器<标签选择器<类选择器<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>CSS 特性-优先级</title><style>/* !important 提权功能,提高优先级到最高,慎用 */*{color:red !important;}div{color:blue;}.ace{color:green;}#test{color:yellow;}</style>
</head>
<body><div class="ace" id="test" style="color:aquamarine">div 标签</div>
</body>
</html>

优先级 - 叠加计算规则

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

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

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

规则:

  • 从左向右依次比较个数,同一级个数多的优先级高,如果个数相同,则向后比较
  • !important权重最高
  • 继承权重最低

三、Emmet写法

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

  • HTML
说明标签结构Emmet
类选择器<div class="box"></dic>标签名.类名
id选择器<div id="box"></div>标签名#id名
同级标签<div></div><p></p>div+p
父子级标签<div><p></p></div>div>p
有多个相同标签<span></span><span></span><span></span>span*3
有内容的标签<div>内容</div>div{内容}
  • CSS

大多数简写方式为属性单词的首字母。

四、背景属性

拆分写法

 1. 背景图

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

属性名:background-image (bgi)

属性值:url(背景图URL)

<!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>div{width: 1600px;height: 1600px;/* 背景图默认是平铺的效果,如果图片不足盒子的面积,就会复制 */background-image: url(./123.jpg);}</style>
</head>
<body><div>div 标签</div>
</body>
</html>

 2. 背景图平铺方式

属性名:background-repeat(bgr)

属性值:

属性值效果
no-repeat不平铺
repeat平铺
repeat-x水平方向平铺
repeat-y垂直方向平铺

3. 背景图位置

属性名:background-poition(bgp)

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

  • 关键字
关键字位置
left左侧
right右侧
center居中
top顶部
bottom底部
  • 坐标(数字+px,正负都可以,这两种方法可以混用)

提示:

  • 关键字取值方式写法,可以颠倒取值顺序
  • 可以只写一个关键字,另一个方向默认为居中;数字只写一个值表示水平方向。

4. 背景图缩放

作用:设置背景图大小

属性名:background-size(bgz)

常用属性值:

  • 关键字

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

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

  • 百分比:根据盒子尺寸计算图片大小
  • 数字+单位(例如:px)

5. 背景图固定

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

属性名:background-attachment(bga)

属性值:fixed

复合写法

属性名:background(bg)

属性值:见上方拆分写法(用空格隔开各个属性值,不区分顺序

五、显示模式

显示模式:标签的显示方式

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

分类:

  • 块级元素:独占一行,宽度默认是父级的100%,添加宽高属性生效
  • 行内元素:一行共存多个,尺寸由内容撑开,加宽高不生效
  • 行内块元素:一行共存多个,默认尺寸由内容撑开,加宽高生效

转换显示模式:

  • 属性名:desplay
  • 属性值:
属性值效果
block块级
inline-block行内块
inline行内

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/19585.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

电路分析基础学习(上)第4章

李瀚荪版电分第二版 目录 求单口网络的VCR 常用等效规律 戴维南定理 诺顿定理 诺顿定理和戴维南定理应该如何选择&#xff0c;或者说对应不同的电路&#xff0c;选择哪一种等效电路更简单&#xff1f; 双口网络 分析含理想二极管的电路 -----------------------------…

Go自带库的使用说明

Go 中的时间操作 Golang中与时间有关的操作&#xff0c;主要涉及到 time 包&#xff0c;核心数据结构是 time.Time&#xff0c;如下&#xff1a; type Time struct {wall uint64ext int64loc *Location }1、获取时间相关函数 1.1 获取当前时间 // 返回当前时间&#xff0c…

APP外包开发硬件通讯协议

开发APP时会遇到需要与硬件设备通讯的业务场景&#xff0c;常见的硬件设备有健康设备(手环、血压计、血糖仪等)、智能家居设备(冰箱、灯、电视等)、工业设备等等&#xff0c;这些设备的通讯要求各不相同&#xff0c;因此通讯协议也不相同。今天和大家分享这方面的知识&#xff…

微服务拆分原则

库存供应链服务 交易和订单服务 用户服务 1. 业务之间耦合降低 相互调用较少 进行拆分 2.修改频率区分不同服务

为什么TCP是面向字节流协议

大家好&#xff0c;我是三叔&#xff0c;很高兴这期又和大家见面了&#xff0c;一个奋斗在互联网的打工人。 笔者在TCP 机制一文中有说到 TCP 是面向字节流的&#xff0c;这篇博客给大家介绍一下&#xff1a;为什么 TCP 是面向字节流协议的。 首先说一下 UDP &#xff0c;是一…

使用python将32位的bmp转成24位的

前言 一个临时需求&#xff0c;要将32位的bmp图像转成24位的 代码 使用opencv读取图片&#xff0c;然后重新存一下就可以。我看有些博主就这个内容还设置了收费&#xff0c;也不害臊。 import cv2if __name__ "__main__":img cv2.imread("IMG-0001-00001.…

目标跟踪基础:数据关联算法

本文来自公众号“AI大道理” —————— 数据关联是多目标跟踪任务中的关键步骤&#xff0c;其目的主要是为了进行帧与帧之间的多个目标的匹配。 1、数据关联 数据关联其实就是一个沿着时间轴&#xff0c;将来自同一个物体的不同时刻的信号串联起来的过程。 数据关联通常在…

桥接(Bridge)模式

目录 动机使用场景参与者优劣协作实现相关模式应用和思考 桥接模式是将抽象部分和它的实现部分分离&#xff0c;使他们都可以独立的变化的对象结构型模式。桥接模式通过将继承改为组合的方式来解决问题&#xff1b;具体来说就是抽取其中一个维度并使之成为独立的类层次。 动机…

开源堡垒机Guacamole二次开发记录之二

这篇主要记录录屏和SFTP的实现。 录屏及视频播放 对于录屏及录屏的播放&#xff0c;因为我们的项目中需要把guacd和java后端分开两台服务器部署&#xff0c;而guacamole的录屏是通过guacd程序录制的。我的要求是在Java后端直接把录好的视频文件通过http前端播放&#xff0c;因…

数据结构(王卓版)——线性表

数据的存储结构之线性表 1、线性表的定义和特点

Python 图书管理系统 GUI界面 (源码在最后)

部分效果图&#xff1a; 部分源码&#xff1a; def creatPage(self):self.addPage AddFrame(self.root)#录入界面self.deletePage DeleteFrame(self.root) #删除界面self.countPage CountFrame(self.root) #统计界面self.register_admirPage Register_admirFrame(self.root…

内卷浪潮中的必考证书——CISP,抓住机会迅速上岸

近年来&#xff0c;随着网络空间安全日趋复杂&#xff0c;网络攻击、病毒入侵、信息失窃、信息泄密事件日益严重&#xff0c;信息安全保障工作被迅速提到了战略高度&#xff0c;能够构建全面的安全体系从而保障组织信息资产安全的专业人才非常紧缺&#xff0c;注册专业资质证书…