1.实例演示相邻选择器与兄弟选择器,并分析异同
#id + * {} 是相邻选择器, 指当前元素后面紧挨着的相邻元素会被选中.
#id ~ * {} 是兄弟选择器,指当前元素后面所有的元素会被选中.
实现效果如下:

实现代码如下:
<style>
div {
width: 40px;
height: 40px;
background-color: red;
border: 1px dashed black;
display: inline-block;
text-align: center;
line-height: 40px;
margin: 20px 4px;
/* 设置DIV的外边距 */
}
ul {
margin: 0;
padding-left: 0;
/* 取消左侧圆点 */
border: 0px dashed red;
/* 边框为虚线,红色,1个像素 */
}
ul li {
list-style-type: none;
width: 50px;
height: 50px;
background-color: wheat;
text-align: center;
line-height: 50px;
/* 水平和垂直的居中 */
border-radius: 50%;
display: inline-block;
/* 将一个块级元素转为内联元素 */
box-shadow: 2px 2px 1px #888;
}
/* 相邻选择器 */
#bg-blue+* {
background-color: yellow;
}
/* 兄弟选择器 */
#green~* {
background-color: green;
}
</style>
</head>
<body>
<ul>
<li>1</li>
<li id=bg-blue>2</li>
<li>3</li>
<li>4</li>
<li>5</li>
<li>6</li>
</ul>
<div>1</div>
<div id="green">2</div>
<div>3</div>
<div>4</div>
<div>5</div>
<div>6</div>
</body>点击 "运行实例" 按钮查看在线实例
2.实例演示:nth-child() 和 :nth-of-type()选择器,并分析异同
伪类: 子元素选择器:nth-child(n) 选择器匹配属于其父元素的第 N 个子元素,不论元素的类型。n 可以是数字、关键词或公式。
实现效果如下:

伪类: 类型选择器,:nth-of-type(n) 选择器匹配属于父元素的特定类型的第 N 个子元素的每个元素.n 可以是数字、关键词或公式。
实现效果如下:

实现代码如下:
<style>
ul {
margin: 0;
padding-left: 0;
/* 取消左侧圆点 */
border: 0px dashed red;
/* 边框为虚线,红色,1个像素 */
}
ul li {
list-style-type: none;
width: 50px;
height: 50px;
background-color: wheat;
text-align: center;
line-height: 50px;
/* 水平和垂直的居中 */
border-radius: 50%;
display: inline-block;
/* 将一个块级元素转为内联元素 */
box-shadow: 2px 2px 1px #888;
}
/* 伪类:子元素选择器 */
ul :first-child {
background-color: coral;
}
/* 选择第一个元素 */
ul :last-child {
background-color: coral;
}
/* 选择最后一个元素 */
ul :nth-child(2) {
background-color: green;
}
/* 选择第二个元素 */
ul :nth-last-child(2) {
background-color: blue;
}
/* 选择倒数第二个元素 */
ul li:first-of-type {
background-color: darkorange;
color: white;
}
ul li:last-of-type {
background-color: darkorange;
color: white;
}
ul li:nth-of-type(2) {
background-color: darkgreen;
color: white;
</style>
</head>
<body>
<ul>
<li>1</li>
<li id=bg-blue>2</li>
<li>3</li>
<li>4</li>
<li>5</li>
<li>6</li>
</ul>
</body>点击 "运行实例" 按钮查看在线实例
3. 实例演示:padding 对盒子大小的影响与解决方案, 使用宽度分离或box-sizing将图片显示在容器中间,演示内边距对盒子大小的影响与解决方案(使用宽度分离或box-sizing)
实现效果如下:

实现代码如下:
<style>
.box1 {
width: 240px;
border: 1px solid black;
background-color: rgb(235, 53, 108);
}
.box1 {
padding: 20px;
width: 200px;
}
/* 使用宽度分离 */
.wrap {
width: 242px;
}
.box2 {
padding: 20px;
background-color: lightsalmon;
border: 1px solid black;
}
/* box-sizing */
.box3 {
width: 242px;
box-sizing: border-box;
padding: 20px;
background-color: pink;
border: 1px solid black;
}
</style>
</head>
<body>
<!-- 将图片显示在容器中间,演示内边距对盒子大小的影响与解决方案(使用宽度分离或box-sizing) -->
<div class="box1">
<img src="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1567562883900&di=df325af2d0000f36c7d42a6cf9792408&imgtype=0&src=http%3A%2F
%2Fi.shangc.net%2F2017%2F0627%2F20170627125731351.jpg" alt="如花" width="200">
</div>
<div class="wrap">
<div class="box2">
<img src="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1567562883900&di=df325af2d0000f36c7d42a6cf9792408&imgtype=0&src=http%3A
%2F%2Fi.shangc.net%2F2017%2F0627%2F20170627125731351.jpg" alt="如花" width="200">
</div>
</div>
<div class="box3">
<img src="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1567562883900&di=df325af2d0000f36c7d42a6cf9792408&imgtype=0&src=http%3A%2F
%2Fi.shangc.net%2F2017%2F0627%2F20170627125731351.jpg" alt="如花" width="200">
</div>点击 "运行实例" 按钮查看在线实例
4. 实例演示: margin中的同级塌陷, 嵌套传递与自动挤压, 并提出解决方案或应用场景
(1)盒子外边框同级塌陷效果 :同级塌陷,谁大向谁挤压

(2) 父级盒子会随内部盒子一起移动,为了解决,让内部盒子内边距增加,宽度再减去内边距,或使用box-sizing: border-box属性
padding和border被包含在定义的width和height之内。对象的实际宽度就等于设置的width值,即使定义有border和padding也不会改变对象的实际宽度,即 ( Element width = width )
实现效果如下:

(3)自动挤压的效果:

<style>
.box1 {
width: 100px;
height: 100px;
background-color: limegreen;
margin-bottom: 50px;
}
.box2 {
width: 100px;
height: 100px;
background-color: red;
margin-top: 30px;
}
.box3 {
box-sizing: border-box;
width: 200px;
height: 200px;
background-color: rgb(245, 125, 125);
}
.box4 {
width: 100px;
height: 100px;
background-color: blue;
}
/* .box4 {
margin-top: 50px;
} */
/* 父级盒子会随内部盒子一起移动,为了解决,让内部盒子内边距增加,宽度再减去内边距 */
.box3 {
padding-top: 50px;
/* height: 150px; */
}
.box5 {
/* 自动挤压 */
width: 150px;
height: 150px;
background-color: cornflowerblue;
}
.box5 {
margin: 30px auto;
}
</style>
</head>
<body>
<!-- 1.同级塌陷,谁大向谁挤压 -->
<div class="box1"></div>
<div class="box2"></div>
<!-- 嵌套传递 -->
<hr>
<div class="box3">
<div class="box4"></div>
</div>
<!-- 自动挤压 -->
<div class="box5"></div>
</body>点击 "运行实例" 按钮查看在线实例
今日总结: 给老师提个优化建议,这个文章编辑器真的很烂,插入代码后,继续输入的内容就变成代码模式, 一边保存,一遍预览,重新排版花了30分钟.也许是我不会用吧.
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号