pink老师HTML5+CSS3学习笔记 | DAY9

目录

1、css的背景样式

①作用

②背景颜色

③背景图片

④背景平铺

⑤背景图片位置(重要)

⑥背景图像固定

⑦背景属性复合写法

⑧背景颜色半透明

2、综合案例-五彩导航

3、css的三大特性

①层叠性

②继承性

③优先级

④权重叠加(重点)

⑤权重练习题


1、css的背景样式

①作用

给页面元素添加背景样式,可以设置为背景颜色、背景图片、背景平铺、背景图片位置、背景图像固定等。实际开发中一些小图标使用img标签插入很难调整其位置,而作为背景再调整更方便;而大图片则可以水平居中,不被浏览器页面大小影响中间显示内容;

②背景颜色

  • 语法:
background-color : transparent | color 
  • 默认值transparent,透明背景;

③背景图片

  • 语法: 
background-image : none | url (url) 
  • 默认值none,没有背景图;

④背景平铺

  • 语法:
/*背景图像在纵向和横向上平铺*/
background-repeat : repeat;

/*背景图像不平铺*/
background-repeat : no-repeat;

/*背景图像在横向上平铺*/
background-repeat : repeat-x;

/*背景图像在纵向平铺*/
background-repeat : repeat-y;
  • 默认值repeat,背景平铺(重复填满盒子)

⑤背景图片位置(重要)

  • 语法:
/*精确坐标,前者表示水平方向上x轴、后者表示垂直方向y轴,有严格顺序*/
background-position : x y;

/*方位名词,前后顺序没影响,可以只设置一个,另一个默认居中*/
/*方位名词:top | center | bottom | left | center | right */
background-position : position position;

/*也可混合使用,如:*/
background-position : center 20px
/*表示x是20,y是center,有严格顺序*/

⑥背景图像固定

  • 语法:
/*背景图像是随对象内容滚动*/
background-attachment : scroll

/*背景图像固定*/
background-attachment : fixed 

⑦背景属性复合写法

  • 语法:
background: 背景颜色 背景图片地址 背景平铺 背景图像固定 背景图片位置;
/*没有固定顺序*/
  • 实际开发中,更提倡复合写法;

⑧背景颜色半透明

  • 语法:
/*alpha就是透明度,取值0~1*/
background: rgba(red, green, blue, alpha);

2、综合案例-五彩导航

/*css*/
a {
	width: 200px;
	height: 200px;
	display: inline-block;
	text-decoration : none;
	color: #000;
	font-size: 26px;
	line-height: 175px;
	text-align: center;
}
a:hover {
	color: gray;
}
.bg1:hover {
	background: #fff url(images/11.png) no-repeat;
}
.bg2:hover {
	background: #fff url(images/22.png) no-repeat;
}
.bg3:hover {
	background: #fff url(images/33.png) no-repeat;
}
.bg4:hover {
	background: #fff url(images/44.png) no-repeat;
}
.bg1 {
	background: #fff url(images/1.png) no-repeat;
}
.bg2 {
	background: #fff url(images/2.png) no-repeat;
}
.bg3 {
	background: #fff url(images/3.png) no-repeat;
}
.bg4 {
	background: #fff url(images/4.png) no-repeat;
}

<!--html-->
<a href="#" class="bg1">五彩导航</a>
<a href="#" class="bg2">五彩导航</a>
<a href="#" class="bg3">五彩导航</a>
<a href="#" class="bg4">五彩导航</a>

3、css的三大特性

  • 层叠性、继承性、优先级

①层叠性

  • 相同选择器设置相同的样式,此时一个样式就会覆盖另一个冲突的样式,层叠性主要解决样式冲突;
  • 如果样式冲突,遵循后来居上原则,执行最后的样式,如:
/*css*/
div {
	color: red;
}
div {
	color: pink;
}
/*执行第二个div选择器里的样式,div中的内容会变成粉色而不是红色*/

<!--html-->
<body>
	<div>我会是粉色</div>
<body>

 

②继承性

  • 子标签会继承父标签的某些样式,文本颜色、字号等,如:
/*css*/
div {
	color: pink;
}

<!--html-->
<div>
	<p>我会跟随父标签div变成粉色</p>
</div>
恰当使用可以简化代码,降低css样式复杂性;
text-, font-, line-这些元素开头的可以继承,以及color属性;
特殊-行高的继承性:
/*加单位:行高设置为24px并给子标签继承*/
font: 12px/24px 'Microsoft YaHei';

/*不加单位:*/
div {
	font-size: 14px;
	/*行高=14px*1.5=21px*/
	font: 12px/1.5 'Microsoft YaHei';
}
p {
	font-size: 16px;
	/*行高=16px*1.5=24px*/
	font: 12px/24px 'Microsoft YaHei';
}

③优先级

  • 当一个元素指定多个选择器,就会有优先级;
  • 原则:
    • 选择器相同,执行层叠性;
    • 选择器不同,根据选择器权重执行;
  • 选择器权重表:权重依次增大,后面的永远大于前面的,不会进位
继承,*0,0,0,0(不论父标签权重多高,子标签继承过来的权重就是0)
元素选择器0,0,0,1
类选择器,伪类选择器0,0,1,0
ID选择器0,1,0,0
行内样式style=""1,0,0,0
!important无穷大∞
  • 应用:
/*css*/
p {
	color: pink!important;
}
.test {
	color: red;
}
#demo {
	color: blueviolet;
}
div{
	color: blue;
}

<!--html-->
<!--类选择器权重>元素选择器,第一个div标签执行类选择器中的样式,文字颜色应为红色-->
<div class="test">你笑起来真好看</div>

<!--ID选择器>类选择器权重>元素选择器,第二个div标签执行id选择器中的样式,文字颜色应为蓝紫色-->
<div class="test" id="demo">你笑起来真好看</div>

<!--行内样式style="">ID选择器>类选择器权重>元素选择器,第三个div标签执行style=""中的内容,文字颜色应为绿色-->
<div class="test" id="demo" style="color: green;">你笑起来真好看</div>

<!--!important>行内样式style="">ID选择器>类选择器权重>元素选择器,p标签执行元素选择器中的样式,文字颜色应为粉色-->
<p class="test" id="demo" style="color: green;">你笑起来真好看</p>

④权重叠加(重点)

  • 复合选择器会有权重叠加的问题
     
/*css*/
/*权重有叠加,但不会进位*/
/* .nav li的权重是0010+0001=0011,从左往右比较0011>ul li的权重0002,使用执行.nav li的样式第二个ul标签的内容为粉色 */
.nav li {
	color: pink;
}
/* ul li的权重是0001+0001=0002(不进位),从左往右比较0002>li的权重0001,使用执行ul li的样式第一个ul标签的内容为蓝紫色 */
ul li {
	color: blueviolet;
}
/* li的权重是0001 */
li {
	color: brown;
}

<!--html-->
<ul>
	<li>1</li>
	<li>2</li>
	<li>3</li>
</ul>
<ul class="nav">
	<li>1</li>
	<li>2</li>
	<li>3</li>
</ul>

⑤权重练习题

  • 问题1:根据已给代码判断:“人生四大悲”是什么颜色?

  • 答:粉色,因为.nav类选择器是父标签ul的,子标签li是继承,元素选择器>继承,所以执行元素选择器内的样式;

  • 问题2:把第一个li颜色改为粉色加粗,其他红色;
  • 答:.nav li权重为0010+0001=0011;.nav .pink权重为0010+0010=0020;.nav li权重<.nav .pink权重,第一个li为粉色加粗;
/*css*/
.nav li {
	color:red;
}
.nav .pink {
	color: pink;
	font-weight: 700;
}
<!--html-->
<ul class="nav">
	<li class="pink">人生四大悲</li>
	<li>家里没宽带</li>
	<li>网速不够快</li>
	<li>手机没流量</li>
	<li>学校没wifi</li>
</ul>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值