本节目标:
-
能使用emmet语法 -
能够使用CSS复合选择器 -
能够写出伪类选择器的使用规范 -
能够说出元素有几种显示模式 -
能够写出元素显示模式的相互转换代码 -
能够写出背景图片的设置方式 -
能够计算CSS的权重
Emmet 语法
Emmet语法的前身是Zen coding,它使用缩写,来提高html/css的编写速度, Vscode内部已经集成该语法.
- 快速生成HTML结构语法
- 快速生成CSS样式语法
data:image/s3,"s3://crabby-images/ee5df/ee5df18ddb4e6edcf8b8dbd1c2e2fd9be035690a" alt="在这里插入图片描述" 打这些符号的时候不要有空格! 第五条默认是div生成的data:image/s3,"s3://crabby-images/271b6/271b6e1e35ea4a60718e76daee05a754ce91938c" alt="在这里插入图片描述" 实例代码:
<body>
<div></div>
<table></table>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<p></p>
<p></p>
<p></p>
<p></p>
<ul>
<li></li>
</ul>
<div><span></span></div>
<div></div>
<p></p>
<div class="nav"></div>
<div class="nav"></div>
<div id="banner"></div>
<p class="one"></p>
<span class="gray"></span>
<ul>
<li id="two"></li>
</ul>
<div class="demo"></div>
<div class="demo1"></div>
<div class="demo2"></div>
<div class="demo3"></div>
<div class="demo4"></div>
<div class="demo5"></div>
<div class="demo1"></div>
<div class="demo2"></div>
<div class="demo3"></div>
<div class="demo4"></div>
<div class="demo5"></div>
<div>pink老师不是gay</div>
<div>我不喜欢男人</div>
<div>我不喜欢男人</div>
<div>我不喜欢男人</div>
<div>我不喜欢男人</div>
<div>我不喜欢男人</div>
<div>1</div>
<div>2</div>
<div>3</div>
<div>4</div>
<div>5</div>
</body>
data:image/s3,"s3://crabby-images/f9139/f9139d49f8ca804f131b3b78b17c0678831bdf2e" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/8243f/8243f174e60774da5947cd8188382ef1bf7c931f" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/379b2/379b24185d31d961452eae2625ce87de251df246" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/dd1c6/dd1c686b65ba66ca01c9077b0306039ef11ccd2b" alt="在这里插入图片描述"
复合选择器
data:image/s3,"s3://crabby-images/2cc6b/2cc6b719387f86b8d454031d529c826f16393a59" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/1ca1c/1ca1cd2eba5fbbc8318dd82645e209ca81dd91a0" alt="在这里插入图片描述"
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>复合选择器之后代选择器</title>
<style>
ol li {
color: pink;
}
ol li a {
color: red;
}
.nav li a {
color: yellow;
}
</style>
</head>
<body>
<ol>
变态写法
<li>我是ol 的孩子</li>
<li>我是ol 的孩子</li>
<li>我是ol 的孩子</li>
<li><a href="#">我是孙子</a></li>
</ol>
<ul>
<li>我是ul 的孩子</li>
<li>我是ul 的孩子</li>
<li>我是ul 的孩子</li>
<li><a href="#">不会变化的</a></li>
</ul>
<ul class="nav">
<li>我是ul 的孩子</li>
<li>我是ul 的孩子</li>
<li>我是ul 的孩子</li>
<li><a href="#">不会变化的</a></li>
<li><a href="#">不会变化的</a></li>
<li><a href="#">不会变化的</a></li>
<li><a href="#">不会变化的</a></li>
</ul>
</body>
</html>
data:image/s3,"s3://crabby-images/a235f/a235f4b62175886d010f13f3929c0913c5b9ff47" alt="在这里插入图片描述" 在制作下拉菜单的时候经常使用。
<style>
.nav>a {
color: red;
}
</style>
</head>
<body>
<div class="nav">
<a href="#">我是儿子</a>
<p>
<a href="#">我是孙子</a>
</p>
</div>
</body>
data:image/s3,"s3://crabby-images/f21c4/f21c487e912f99a0985f0a1d23f69ee971d32bc5" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/c004a/c004a562b21101ca5db4313b14400746ca259068" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/8da75/8da7576ed309c730956ecfb6aa07e820e35706bf" alt="在这里插入图片描述"
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>复合选择器之并集选择器</title>
<style>
div,
p,
.pig li {
color: pink;
}
</style>
</head>
<body>
<div>熊大</div>
<p>熊二</p>
<span>光头强</span>
<ul class="pig">
<li>小猪佩奇</li>
<li>猪爸爸</li>
<li>猪妈妈</li>
</ul>
</body>
</html>
data:image/s3,"s3://crabby-images/7ea3a/7ea3a2c933a98db7dd7e5c3adc53dbdb659bb20c" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/796be/796bee327fb5186f95d6c7694320df43730b9f6c" alt="在这里插入图片描述"
像这种网页上鼠标碰到后出现的样式。
data:image/s3,"s3://crabby-images/4d679/4d679b55783660ea6c271bb1cbc5f9460422d45b" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/43e1e/43e1e20da307c6e4bebdb1a2868554995806bb60" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/cb965/cb965a3daf4d9af8038f9f258ed826652eff23e3" alt="在这里插入图片描述" 代码:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>复合选择器之链接伪类选择器</title>
<style>
a:link {
color: #333;
text-decoration: none;
}
a:visited {
color: orange;
}
a:hover {
color: skyblue;
}
a:active {
color: green;
}
</style>
</head>
<body>
<a href="#">小猪佩奇</a>
<a href="http://www.xxxxxxxx.com">未知的网站</a>
</body>
</html>
data:image/s3,"s3://crabby-images/33e6f/33e6f58ca5d008079537fd10e9d9ffe4c3043ea4" alt="在这里插入图片描述"
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>focus伪类选择器</title>
<style>
input:focus {
background-color: pink;
color: red;
}
</style>
</head>
<body>
<input type="text">
<input type="text">
<input type="text">
</body>
</html>
data:image/s3,"s3://crabby-images/f6c29/f6c298433b227db46a7f812dbb0f6d359eb76ca8" alt="在这里插入图片描述"
CSS 的元素显示模式
1.什么是元素的显示模式
data:image/s3,"s3://crabby-images/94ae4/94ae4dd9399b9252dfbc7458cadd3036970ad418" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/1a801/1a801ce0252376f34f2b5b54a5f47ab148c6acf0" alt="在这里插入图片描述"
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>显示模式之块级元素</title>
<style>
div {
height: 200px;
background-color: pink;
}
</style>
</head>
<body>
<div>比较霸道,自己独占一行</div> 瑟瑟发抖
<p>
<div>这里有问题</div>
</p>
</body>
</html>
data:image/s3,"s3://crabby-images/45f63/45f639fcef70027ae224b8d5b936ec6e3f59a31e" alt="在这里插入图片描述" 但是最好把a转换一下 data:image/s3,"s3://crabby-images/96dc1/96dc1b8c64672a63dff0f888d5dfe8d82282bb5a" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/1f42a/1f42a337315895455c3cb6c0aa7f84f9fb126fc3" alt="在这里插入图片描述"
元素显示模式转换
data:image/s3,"s3://crabby-images/14586/14586157d8eee28476be55709971af8998b90005" alt="在这里插入图片描述"
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>元素显示模式转换</title>
<style>
a {
width: 150px;
height: 50px;
background-color: pink;
display: block;
}
div {
width: 300px;
height: 100px;
background-color: purple;
display: inline;
}
span {
width: 300px;
height: 30px;
background-color: skyblue;
display: inline-block;
}
</style>
</head>
<body>
<a href="#">金星阿姨</a>
<a href="#">金星阿姨</a>
<div>我是块级元素</div>
<div>我是块级元素</div>
<span>行内元素转换为行内块元素</span>
<span>行内元素转换为行内块元素</span>
</body>
</html>
一个小工具的使用 snipaste
data:image/s3,"s3://crabby-images/a0ae9/a0ae91750e6ff0ab7d624793737fb16554e2fc3e" alt="在这里插入图片描述"
案例:简洁版小米侧边栏
案例的核心思路分为两步:
- 把链接a 转换为块级元素, 这样链接就可以单独占一行,并且有宽度和高度.
- 鼠标经过a 给 链接设置背景颜色
data:image/s3,"s3://crabby-images/d92c9/d92c91106da6fd320ff5b28d76a76c478dfd5415" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/d378f/d378f45da82170b4ee25a4648f350642ddf701ad" alt="在这里插入图片描述"
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>简单版小米侧边栏</title>
<style>
a {
display: block;
width: 230px;
height: 40px;
background-color: #55585a;
font-size: 14px;
color: #fff;
text-decoration: none;
text-indent: 2em;
line-height: 40px;
}
a:hover {
background-color: #ff6700;
}
</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>
data:image/s3,"s3://crabby-images/a4884/a4884b4ecc5e0b7b51224047cc49e26838a0a59e" alt="在这里插入图片描述"
偏上或偏下的情况。
data:image/s3,"s3://crabby-images/c339a/c339a8bd574b49612b6f8894a2134d40a7d324a1" alt="在这里插入图片描述"
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>单行文字垂直居中</title>
<style>
div {
width: 200px;
height: 40px;
background-color: pink;
line-height: 40px;
}
</style>
</head>
<body>
<div>我要居中</div>
</body>
</html>
https://movie.douban.com/top250?start=100&filter=
|