CSS选择器+盒子模型+定位( 基础笔记 )

CSS学习笔记

 CSS
	-层叠样式表
	-网页实际上是一个多层的结构,通过CSS可以分别为网页的每一个层来设置样式,而最终我们能看到只是网页的最上边的一层
	-总之一句话,CSS用来设置网页中元素的样式

使用CSS来修改元素的样式

-第一种方式(内联样式/行内样式)不推荐使用:
	-在标签内部通过style属性来设置元素的样式
	-使用内联样式,样式只能对一个标签生效,多个标签同时使用时,不方便维护
	-注意:开发时绝对不要使用内联样式
-第二种方式(内联样式表):
	-将样式编写到head的style标签里,然后通过CSS选择器来选中元素并为其设置各种格式,可以为多个标签设置样式,并且只需要修改一处即可
	-内部样式表更加方便对样式进行复用
	-注意:内联样式表只能对一个网页起作用,它里面的样式不能跨网页复用
-第三种方式(外部样式表)最佳实践:
	-可以将CSS样式编写到一个外部的CSS文件中,然后通过link标签引入外部的CCS文件
	-外部样式表需要通过link标签来引人,意味着只要想使用这些样式的网页都可以对其进行引用,使样式可以在不同页面之间进行复用
	-将样式编写到外部的CSS文件中,可以使用到浏览器的缓存机制,从而加快网页的加载速度,提高用户体验

CSS的基本语法

-选择器:
	-通过选择器可以选中页面中的指定元素
-声明块:
	-	通过声明块来指定要为元素设置的样式
	-	声明块由一个一个的声明组成
	-	声明块时一个名值对结构,一个样式名对应一个样式值,名和值之间以: 连接,以; 结尾

-常用选择器
	-元素选择器:
		作用:根据标签名来选中指定的元素
		语法:标签名{}
		例子:p{}  h1{}  div{}
	-id选择器:
		作用:根据元素的id属性值选中一个元素
		语法:#id属性值{}
		例子:#abc{}
	-class选择器是一个标签的属性,它和id类似,不同的是class可以重复使用,可以通过classs属性来为元素分组
	-通配选择器:
		作用:选中页面的所有元素
		语法:*
	-交集选择器:
		作用:选中同时复合多个条件的元素
		语法:选择器1选择器2选择器3...选择器n{}
		注意:交集选择器中的所有元素选择器,必须使用元素选择器开头
		例子:div.red{}
	-并集选择器(选择器分组):
		作用:同时选择多个选择器对应的元素
		语法:选择器1,选择器2,选择器3,...,选择器n{}
		例子:#abc,p,div.red{}
	
-关系选择器
	父元素:直接包含了子元素的元素叫父元素
	子元素:直接被父元素包含的元素叫子元素
	祖先元素:直接或间接包含后代元素的元素叫祖先元素,一个元素的父元素也是它的祖先元素
	后代元素:直接或间接被祖先元素包含的元素叫后代元素,子元素也是后代元素
	兄弟元素:拥有相同父元素的兄弟元素
	
	-子元素选择器:
		作用:选中指定父元素的指定元素
		语法:父元素>子元素
		例子:div.red > span{}
	
	-后代元素选择器:
		作用:选中指定元素内的指定后代元素
		语法:祖先 后代
		例子:div span{}
	
	-兄弟元素选择器:
		-选择下一个兄弟
			语法:前一个 + 后一个
			例子:p + span{}
		-选择下面所有兄弟
			语法:兄 ~ 弟
			例子:p ~ span
	
-属性选择器
	[属性名] 选择含有指定属性的元素
	[属性名=属性值] 选择含有指定属性和属性值的元素
	[属性名^=属性值] 选择属性值以指定值‘开头’的元素
	[属性名$=属性值] 选择属性值以指定值‘结尾’的元素
	[属性名*=属性值] 选择属性值中’含有某值‘的元素的元素

-伪类选择器
	伪类(不存在的类,特殊的类)
		-伪类用来描述一个元素的特殊状态
			例如:一个子元素,被点击的元素,鼠标移入的元素...
		-伪类一般情况下都是使用: 开头
			:first-child 第一个子元素
			:last-child 最后一个子元素
			:nth-child() 选中第n个子元素
				特殊值:
					n(第n个)n的范围0到正无穷
					2n 或者 even 表示选中偶数位的元素
					2n+1 或者 odd 表示选中奇数位的元素
				-以上这些伪类都是根据所有的子元素进行排序
				
			:first-of-type
			:last-of-type
			:nth-of-type()
				-这几个伪类的功能和上述的类似,不通点是他们是在'同类型元素中'进行排序
				例如: ul > li:first-of-type
			
		-:not()否定伪类,将符合条件的元素从选择器中去除
	

	-a标签相关(超链接)的伪类
		-	a:link 用来表示没有访问过的链接(正常的链接)
		-	a:visited 用来表示访问过的链接
				由于隐私的原因,所以visited这个伪类只能修改链接的颜色
		- :hover 用来表示鼠标移入的状态
		-  :active 用来表示鼠标点击
	

-伪元素
	伪元素表示页面中一些特殊的并不真实存在的元素(特殊位置)
		伪元素使用 :: 开头
		
		::first-letter 表示第一个字母
		::first-line 表示第一行
		::selection 表示选中的内容
		::before 元素的开始
		::after 元素的结束
			before和after 必须结合content属性来使用
			例如:div::before{content: "abc";}

选择器的权重:

样式的冲突:当我们通过不同的选择器,选中相同的元素,并且为相同的样式设置不同的值时,此时发生了样式的冲突。
发生样式冲突时,应用哪个样式由选择器的权重(优先级)决定

选择器的权重:			优先级
	内联样式				1,0,0,0
	id选择器				0,1,0,0
	类和伪类选择器		0,0,1,0
	元素选择器			0,0,0,1
	通配选择器			0,0,0,0
	继承的样式			没有优先级

比较优先级,需要将所有的选择器的优先级进行相加计算,最后优先级越高,则越优先显示(分组选择器是单独计算的)
	-选择器的累加不会超过其最大的数量级,类选择器再高不会超过id选择器(不会超过前一位)
	-如果优先级计算后相同,此时则优先使用靠下的样式

可以在某一个样式的后面添加 !important,则此时该样式会获得到最高的优先级,甚至超过内联样式(注意:在开发中一点要慎用)

-


继承

  1. 样式的继承,我们为一个元素设置的样式同时也会应用到它的后代元素上

  2. 继承是发生在祖先的后后代之间的

  3. 继承的设计是为了方便我们的开发,利用继承我们可以将一些通用的样式统一设置到共同的祖先元素上,这样只需设置一次就可以让所以元素继承样式

  4. 注意:并不是所有样式都会被继承:
    比如:背景相关的,布局相关等的这些样式都不会被继承。


像素和百分比

  1. 长度单位:像素(px)
    -屏幕(显示器)实际上上由一个一个的小点点构成的
    -不同屏幕的像素大小是不同的,像素越小的屏幕显示的效果越清晰
    -所以同样的200px在不同的设备下显示效果不一样

  2. 百分比:
    -也可以将属性值设置为相对于其父元素属性的百分比
    -设置百分比可以使子元素跟随父元素的改变而改变

  3. em:
    -em是相对于元素的字体大小来计算的
    -1em = 1front-size
    -em 会根据字体大小的改变而改变

  4. rem:
    -rem 相对于根元素的字体大小来计算的


RGB值

颜色单位:
在CSS中可以直接使用颜色名来设置各种颜色
- 比如:red,blue,yellow…
- 但是在CSS中直接使用颜色名是非常的不方便

RGB值:
	- RGB通过三种颜色的不同浓度来调配出不同的颜色
	- R red,  G green,  B blue
	- 每一种颜色的范围在0~255(0%~100%)之间
	- 语法:RGB( 红色,绿色,蓝色 )

RGBA:
	- 就是在RGB的基础上增加了一个a表示不透明度
	- 需要四个值,前三个和rgb一样,第四个表示不透明度
	-   1表示完全不透明    0表示完全透明	.5表示半透明

十六进制的RGB值:
	- 语法:#红色绿色蓝色
	- 颜色浓度通过 00-ff(最大)
	- 如果颜色两位两位重复可以进行简写,例如:#aabbcc --> #abc

HSL值/HSLA值:
	- H 色相(0~360)
	- S 饱和度,颜色的浓度(0%~100%)
	- L 亮度,颜色的亮度(0%~100%)


文档流

文档流(normal flow)
	- 网页是一个多层的结构,一层夹着一层
	- 通过CSS可以分别为每一层来设置样式
	- 作为用户来讲只能看到最顶上一层
	- 这些层,最底下的一层称为文档流,文档流是网页的基础
		我们所创建的元素默认都是在文档流中进行排列
		
	- 对于我们来说,元素主要有两个状态:
		·在文档流中
		·不在文档流中(脱离文档流)
	
	- 元素在文档流中有什么特点?
		-块元素
			- 块元素会在页面中独占一行
			- 默认宽度是父元素的全部(会把父元素撑满)
			- 默认高度是被内容撑开(子元素)
			
		- 行内元素
			- 行内元素不会独占页面的一行,只占自身的大小
			- 行内元素在页面中自左向右水平排列,如果一行之中不能容纳下所有的行内元素,则元素会换到第二行继续自左向右排列(书写习惯一致)
			- 行内元素的默认宽度和高度都是被内容撑开


盒子模型

·盒模型、盒子模型、框模型(box model)
	- CSS将页面中的所有元素都设置成为一个矩形的盒子
	- 将元素设置为矩形的盒子后,对页面的布局将变成将不同的盒子摆放到不同的位置
	- 每一个盒子都有以下几个部分组成:
		1. 内容区(content)
			元素中的所有的子元素和文本内容都在内容区中排列
				内容区的大小由width和height两个属性来设置
					width:设置内容区的宽度
					height:设置内容区的高度
				
		2. 内边距(padding)
		3. 边框(border)
			边框属于盒子边缘,边缘里边属于盒子内部,出了边框都是盒子的外部(边框的大小会影响整个盒子的大小)
				要设置边框,需要至少设置三个样式:	
					边框的宽度 border-width
					边框的颜色 border-color
					边框的样式 border-style
		4. 外边距(margin)


·盒子模型-边框
	-border-width:
		默认值:一般为3个像素
		border-width 可以用来指定四个方向的边框的宽度
			值的情况:
				四个值:上 右 下 左
				三个值:上 左右 下
				两个值:上下 左右
				一个值:上下左右
			除了border-width还有一组 border-xxx-width (xxx可以是top right bottom left-用来单独指定某一个边的宽度)
	
	-border-color:		
			border-color 用来指定边框的颜色,同样可以分别指定四个边的边框(规则和border-width一样)
			border-color也可以省略不下,如果省略了则自动使用color的颜色值
	
	-border-style:
		border-style指定边框的样式
			solid表示实线
			dotted表示点状虚线
			dashed表示虚线
			double表示双线
			
			border-style的默认值是none,表示没有边框
			
	-border简写属性,通过该属性可以同时设置边框所有的相关样式,并且咩呀顺序要求
	除了border意外还有四个 border-xxx (top, right, bottom, left )
	
	
·盒子模型-内边距
	内边距(padding):	
		- 内容区和边距之间的距离是内边距
			padding:上 右 下 左
		- 一共有四个方向的内边距:
			padding-top
			padding-right
			padding-bottom
			padding-left
		
		- 内边距的设置会影响到盒子的大小
		- 背景颜色会延伸到那边啥内边距上
		
	- 一个盒子的可见框的大小,可由内容区,内边距和边框共同决定
		所以在计算盒子大小时,还需要将这三个区域加到一起计算
	
		
·盒子模型-外边距
	外边距(margin):
		- 外边距不会影响盒子可见框的大小
		- 但是外边距会影响盒子的位置
		- 一个有四个方向的外边距
			margin-top
				-上外边距,设置一个正值,元素会向下移动
			margin-right
				-默认情况下设置margin-right不会产生任何效果
			margin-bottom
				-下外边距,设置一个正值,其下边的元素会向下移动
			margin-left
				-左外边距,设置一个正值,元素会向右移动
			(margin也可以设置为负值,如果是负值则元素会向相反方向移动)
			
		-元素在页面中说按照自左向右的顺序排列的
			所以默认情况下如果我们设置的左和上外边距则会移动自身元素
			而设置右和下外边距会移动其他元素
		
		- margin的简写属性:
			margin 可以同时设置四个方向的外边距,用法和padding一样
		
		-margin 会影响到盒子实际占用的空间


·盒子模型-水平方向的布局
	元素的水平方向的布局:
		元素在其父元素中水平方向的位置由以下几个属性共同决定:
			margin-left
			border-left
			padding-left
			width
			padding-right
			border-right
			margin-left
			
			一个元素在其父元素中,水平布局 ‘必须要满足’ 以下的等式:
			margin-left + border-left + padding-left + width + padding-right + border-right + margin-left = 其父元素内容区的宽度(必须满足)
			
			-以上等式必须满足,如果相加结果使等式不成立,则称为过度约束,则等式会自动调整
				-调整的情况:
					-如果这七个值中没有为auto的情况,则浏览器会自动调整margin-right的值使等式满足(当子元素宽度大于父元素宽度时,margin-right的值为负数)
				-这七个值中有三个值课设置为auto
					width
					margin-left
					margin-right
					
				-如果某个值为auto,则会自动调整为auto的那个值来使等式成立
				-如果将一个宽度和一个外边距设置为auto,则宽度会调整到最大,设置为auto的那个外边距会自动为0
				-如果将三个值都设置为auto,则外边距都是0,宽度最大
				-如果将两个两个外边距设置为auto,宽度固定值,则回将两个外边距设置为相同的值
					我们经常利用这个特点来使一个元素在其父元素中水平居中
					例子:
						margin: xxpx;
						margin: 0 auto;


·盒子模型-垂直方向的布局
	-默认情况下父元素的高度被内容撑开
	- 子元素是父元素的内容区中排列的:
		如果子元素的大小超过了父元素,则子元素会从父元素中溢出
		
		使用 overflow 属性来设置父元素如何处理溢出的子元素
		可选值:
			visible:默认值 子元素会从父元素中溢出,在父元素外部的位置显示
			hidden:溢出内容将会被裁剪不会显示
			scroll:生成两个滚动条,通过滚动条来查看完成整内容
			auto:根据需要生成滚动条

				
·盒子模型-外边距的重叠(折叠)
	-相邻的垂直方向外边距会发生重叠现象
	-兄弟元素
		-兄弟元素间的相邻垂直外边距会取两者之间的较大值(两者都是正值)
		-特殊情况:
			如果相邻的外边距一正一负,则取两者的和
			如果相邻的外边距都是负值,则取两者中绝对值较大的
		-兄弟元素之间的外边距的重叠,对于开发是有利的,所以我们不需要进行处理
	
	-父子元素
		- 父子元素之间相邻外边距,子元素的会传递给父元素(上外边距)
		- 父子外边距的折叠会影响到页面的布局,必须要进行处理


·盒子模型-行内元素
	- 行内元素不支持设置宽度和高度
	- 行内元素可以设置padding,但是垂直方向padding不会影响页面的布局
	- 行内元素可以设置border,垂直方向的border不会影响页面的布局
	- 行内元素可以设置margin,垂直方向的margin不会影响页面的布局
	
	- display 可以用来设置元素显示的类型
		可选值:
			inline:将元素设置为行内元素
			block: 将元素设置为块元素
			inline-block:将元素设置为行内块元素
				行内块元素,即可以设置宽度和高度又不会独占一行
			table:将元素设置为一个表哥
			none:元素不在页面中显示
	
	- visibility 可以用来设置元素显示状态
		可选值:
			visible(默认值):元素在页面正常显示
			hidden:元素在页面中隐藏(不显示),但是依然占据页面的位置



·高度塌陷和BFC
	高度塌陷的问题:
		- 在浮动布局中,父元素的高度默认是被子元素撑开的,当子元素浮动后,其会完全脱离文档流,子元素从文档流中脱离,将会无法撑起父元素的高度,导致父元素的高度丢失。
			
		- 父元素高度丢失以后,其下的元素会自动上移,导致页面的布局混乱

		- 高度塌陷是浮动布局中比较常见的一个问题,这个问题我们必须要进行处理
	
	BFC ( Block Formatying Context )	块级格式化环境
		-BFC是一个CSS中的一个隐含的属性,可以为一个元素开启BFC
			开启BFC该元素会变成一个独立的布局区域
		
		- 元素开启BFC后的特点:
			1. 开启BFC的元素不会被浮动元素所覆盖  
			2. 开启BFC的元素的子元素和父元素外边距不会重叠
			3. 开启BFC的元素可以包含浮动的子元素
		
		-可以通过一些特殊方式来开启元素的BFC:
			1. 设置元素的浮动(不推荐)
			2. 将元素设置为行内块元素(不推荐)
			3. 将元素的overflow设置为一个非visible的值
				-常用方式:为元素设置overflow: hidden 开启BFC(以使其可以包含浮动元素)


· clear
	- 如果我们不希望某个元素因为其他元素浮动的影响而改变位置,可以通过clear属性来清除元素对当前元素所产生的影响
	- clear:
		- 作用:清除浮动元素对当前元素所产生的影响
		- 可选值:
			left:清除左侧浮动元素对当前元素的影响
			right:清除右侧浮动元素对当前元素的影响
			both:清除两侧浮动元素影响最大的那侧

·高度塌陷的最终解决方案(使用after伪类)
	.box::after{
		content: '';
		display: block;
		clear: both;
	}
		
		解决高度塌陷和外边距重叠(同时解决方案):
			.clearfix::before,
			.clearfix::after{
				content: '';
				display: table;
				clear: both;
			}


定位

定位(position)
	- 定位是一种更加高级的布局手段
	- 通过定位可以将元素摆放到页面的任意位置
	- 使用position属性来设置定位
		可选值:
			static:默认值,元素是静止的没有开启定位
			relative:开启元素的相对定位
			absolute:开启元素的绝对定位
			fixed:开启元素的固定定位
			sticky:开启元素的粘滞定位
	
	
	- 相对定位(position: relative):
		- 当元素的position属性值设置为relative时则开启了元素的相对定位
		- 相对定位的特点:
			1. 元素开启相对定位以后,如果不设置偏移量元素不会发生任何的变化
			2. 相对定位时参照于元素在文档流中的位置进行定位的
			3. 相对定位会提升元素的层级
			4. 相对定位不会使元素脱离文档流
			5. 相对定位不会改变元素的性质块还是块,行内还是行内
		
		- 偏移量(offset)
			- 当元素开启了定位以后,可以通过偏移量来设置元素的位置
				top:-定位元素和定位位置上边的距离
				bottom:- 定位元素和定位位置下边的距离
						- 定位元素垂直方向的位置由top和bottom两个属性来控制
						- 通常情况下我们只会使用其中之一
							- top值越大,定位元素越向下移动
							- bottom值越大,定位元素越向上移动
						
				left:-定位元素和定位位置的左侧的距离
				right:	-定位元素和定位位置的右侧的距离
						- 定位元素垂直方向的位置由left和right两个属性来控制
						- 通常情况下我们只会使用其中之一
							- left值越大,定位元素越向右移动
							- right值越大,定位元素越向左移动
		
		-绝对定位(position: absolute; )
			-当元素的position属性值设置为absolute时,则元素开启了元素的绝对定位
			- 绝对定位的特点:
				1. 开启了绝对定位后,如果不设置偏移量元素的位置不会发生变化
				2. 开启绝对定位后,元素会从文档流中脱离
				3. 绝对定位会改变元素的性质,行内元素变成块,块的宽度和高度被内容撑开
				4. 绝对定位会使元素提升一个层级
				5. 我们的绝对定位元素使相对于其包含块元素进行定位的 
				
				包含块元素(containing block)
					- 正常情况下:
						包含块就是离当前元素最近的祖先快元素
						例如:<div><span></span></div>

					- 绝对定位的包含块:
					包含块就是离它最近的开启了相对定位的祖先元素,如果所有的祖先元素都没有开启相对定位则根元素就是它的包含块
					- html (根元素、初始包含块)
		
		-固定定位(position: fixed; )
			- 将元素的position属性设置为fixed则开启了元素的固定定位
			- 固定定位也是一种绝对定位,所以固定定位的大部分特点都和绝对定位一样
			- 唯一不同的是,固定定位永远参照于浏览器的视口进行定位
				固定定位的元素不会随着页面的滚动条滚动

		- 粘滞定位(position: sticky)
			- 当元素的position属性设置为sticky时则开启了元素的粘滞定位
			- 粘滞定位和相对定位的特点基本一样,不同的是粘滞地位可以在元素到达某个位置时将其固定



- 绝对定位元素的布局
	- 水平布局
		- 垂直方向布局的等式必须满足
			left + margin-left + border-left + padding-left + width + padding-right + border-right + margin-left  + right = 其父元素内容区的宽度
		
	- 当我们开启了绝对定位后:
		- 水平方向的布局等式就要添加 left 和 right 两个值,此时规则和之前一样,只是多添加了两个值。
			- 当发生过度约束:
				如果9个值中没有 auto则自动调整right 的值以使等式满足
				如果有auto, 则自动调整auto的值使等式满足
			
			-可设置auto的值:
				margin  width  left  right

			-因为left 和right 的值默认是auto,所以如果不知道left和right的值,则等式不满足时,会自动调整这两个值  

	- 垂直布局
		- 垂直方向布局的等式必须满足
			top + margin-top/bottom +padding-top/bottom + border-top/bottom + height =  包含块的高度

	- 元素的水平垂直居中代码:
		.box{
			margin: auto;
			top:0;
			bottom:0;
			left:0;
			right:0;
		}


元素的层级

对于开启了定位元素,可以通过z-index属性来指定元素的层级	:
	- z-index需要一个整数作为参数,值越大元素的层级越高,元素的层级越高越优先显示
	- 如果元素的层级相同,会优先显示靠下的元素
	- 祖先元素的层级再高也不会盖住后代元素


字体族

字体相关的样式:
	color:用来设置字体颜色
	font-size:用来设置字体的大小
		- 和font-size相关的单位:
			em相当于当前元素的一个font-size
			rem相当于根元素的一个font-size
			

- font-family 字体族(字体样式)
	可选值:
		serif:衬线字体
		sans-serif:非衬线字体
		monospace:等宽字体
			- 指定字体的类别,浏览器会自动使用该类别下的字体

	- font-family 可以同时指定多个字体,多个字体间使用,隔开
				字体生效时优先使用第一个,第一个无法使用则使用第二个,以此类推			
	
	-font-face 可以将服务器中的字体直接提供给用户去使用
		- 问题:
			1. 加载速度
			2. 版权问题
		- 用法:
			@font-face{
				font-family: 'myfont';
				src: url('./路径');
			}


图片字体

· 图片字体(iconfront)
	-在网页中经常需要使用一些图标,可以通过图片来引入图标
		但是图片的大小本身比较大,并且非常不灵活
	- 所以在使用图片时,我们还可以将图片直接设置为字体,然后通过font-face的形式来对字体进行引入
	- 这样我们可以通过使用字体的样式的形式来使用图标

· fontawesome 使用步骤:
	1. 下载https://fontawesome.com/
	2. 解压
	3. 将css和webfonts移动到项目中
	4. 将all.css引入到网页中
	5. 使用图标字体
		- 直接使用类名来使用图标字体

· 图标字体的其他使用方式
	通过伪元素来设置图标字体
		1. 找到要设置图标的元素通过before或after选中
		2. 在content中设置字体的编码
		3. 设置字体的样式:
			fab:
			font-family: 'Font Awesome 5 Brands'

			fas:
			font-family: 'Font Awesome 5 Brands';
			font-weight: 900;
			
		4. 通过实体来使用图标字体:
			&#( 图标的编码 ); 

· 阿里字体图标库( iconfront)


行高

行高(line height)
	- 行高指的是文字占有的实际高度
	- 可以通过line-height来设置行高
		行高可以直接指定一个大小(px  em),也可以直接为行高设置一个整数
		如果是一个整数的话,行高将会是字体的指定的倍数
	- 行高经常还用来设置文字的行间距
	- 行间距 = 行高 - 字体大小

字体框
	- 字体框就是字体存在的格子,设置font-size实际上就是在设置字体框的高度

	- 行高会在字体框的上下平均分配
	 通常将行高设置为和高度一样的值,使单行文字在一个元素中垂直居中


字体的简写属性

· font 可以设置字体相关的所有属性
	语法:
		font :字体大小/行高    字体族 (行高可以省略不写,如果不写会使用默认值)

· font-weight 字重,字体的加粗
	可选值:
		normal:默认值,不加粗
		bold:加粗
		100-900 九个级别(没有区别)
	
· font-style 字体的风格
	normal 正常的
	italic 斜体


文本的水平和垂直对齐

· text-align:文本的水平对齐
	可选值:
		left:左侧对齐
		right:右侧对齐
		center:居中对齐
		justify:两端对齐

· vertical-align:文本的垂直对齐
	可选值:
	baseline:默认值,基线对齐
	top:顶部对齐
	bottom:底部对齐
	middle:居中对齐

· 其他的文本样式
	- text-decoration:设置文本修饰
		可选值:
			none:什么都没有
			underlin:下划线
			line-through:删除线
			overline:上划线
	
	- white-space:设置网页如何处理空白
		可选值:
			normal:正常
			nowrap:不换行
			pre:保留空白


背景

· background-color(设置背景颜色)
· backgro-image(设置背景图片)
 	- 可以同时设置背景图片和背景颜色,这样背景颜色将会将会成为背景图片的背景色
 	- 如果背景图片小于元素,则背景图片会自动在元素中平铺,将元素铺满
 	- 如果背景的图片大于元素,将会一个部分背景无法完全显示
 	- 如果背景图片和元素一样大,则会直接正常显示

· background-repeat(用来设置背景的重复方式)
	可选值:
		repeat :默认值,背景会沿着x轴 y轴双方向重复
		repeat-x:沿着x轴的方向重复
		repeat-y:沿着y轴的方向重复
		no-repeat:背景图片不重复

· background-position(用来设置背景图片的位置)
	可选值:
		- 通过 top  left  right  bottom  center 几个表示方位的词来设置背景图片的位置
		- 使用方位词时必须同时指定两个值,如果只写一个则第二个默认就是center
		- 通过偏移量来设置背景图片的位置:
			水平方向的偏移量,垂直方向的偏移量

· background-clip(设置背景的范围)
	可选值:
		border-box:默认值,背景会出现在边框的下边
		padding-box:背景不会出现在边框,只出现在内容区和边框
		content-box:背景只会出现在内容区

· background-origin(背景图片的偏移量计算的原点)
	可选值:
		padding-box:默认值,background-position从内边距处开始计算
		content-box:背景图片的偏移量从内容区开始处计算
		border-box:背景图片的变量从边框处开始计算

· background-size(设置背景图片的大小)	
	- 第一个值表示宽度
	- 第二个值表示高度
		- 如果只写一个值,则第二个值默认是auto
	- cover:图片的比例不变,将元素铺满
	- contain:图片的比例不变,将图片在元素中完整显示

· background-attachment(背景图片是否跟随元素移动)
	可选值:
		scroll:默认值,背景图片会跟随元素移动
		fixed:背景图片会固定在页面中,不会随元素移动

· background背景相关的简写属性,所有背景相关的样式都可以通过该样式来设置,并且该样式没有顺序要求,也没有哪个属性是必须写的

· 注意:
	- background-size:必须写在background-position的后面,并且使用/隔开
		background-position/background-size
	- background-origin  background -clip两个样式,origin必须在clip的前面
	
· 图片闪烁问题:
- 图片属于网页中的外部资源,外部资源都需要浏览器单独发送请求加载,浏览器加载外部资源时是按需加载的(用则加载,不用则不加载)
- 解决图片闪烁的问题:
	1. 可以将多个小图片统一保存到一个大图片中,然后通过调整backgr-position开显示相应的图片
	2. 这样图片会同时加载到网页中,就可以有效的避免来闪烁问题
	3. 这个技术在网页中的应该十分广泛,被称为CSS-Sprite,这种图我们称为雪碧图
	

· 线性渐变
	- 通过渐变可以设置一些复杂的背景颜色,可以实现从一个颜色向其他颜色过渡的效果
	!!渐变是图片,需要通过background-image来设置

	- 线性渐变,颜色沿着一条直线发生变化 linear-gradient()
		例子:linear-gradient(red,yellow)红色在开头,黄色在结尾,中间是过渡区域
		- 线性渐变的开头,我们可以指定一个渐变的方向
			to left: 向左
			to right:向右
			to bottom:向下
			to top:向上
			xxxdeg (deg表示度数)
			turn (表示圈)
		- 渐变可以同时指定多个颜色,多个颜色默认情况下平均分布
			repeating-linear-gradient()可以平铺的线性渐变

· 径向渐变
	radial-gradient()径向渐变(放射性的效果)
	- 默认情况下,径向渐变圆心的形状根据元素的形状来计算的
		正方形-->圆形
		长方形-->椭圆形
		
	-我们也可以手动指定径向渐变的大小,也可以指定渐变的位置
		- 语法:
			radial-gradient(大小  at  位置,颜色  位置,颜色  位置...)
		- 大小:
			circle:圆形
			ellipse:椭圆
			closet-side:近边
			closet-corner:近角
			farthest-side:远边
			farthest-corner:远角
						
		- 位置:
			top  right  left  center  bottom


雪碧图

- 雪碧图的使用步骤:
	1. 先确定要使用的图标
	2. 测量图标的大小
	3. 根据测量结果创建一个元素
	4. 将雪碧图设置为元素的背景图片
	5. 设置一个偏移量以显示正常的图片

- 雪碧图的特点:
	一次性将多个图片加载进页面,降低请求的次数,加快访问速度,提升用户体验
	

<br></br>

表格的简介

- 在我们现实社会中,我们经常需要使用表格表示一些格式化数据(课程表、人名单、成绩单...)

- 表格的创建
	- 同样在网页中我们也需要使用表格,我们通过table标签来创建一个表格
	- 在table中使用tr表示表格中的一行,有几个tr就有几行
	- 在tr中使用td表示一个单元格,有几个td就有几个单元格
	- colspan 横向的合并单元格
	- rowspan 纵向的合并单元格

- 长表格
	可以将一个表格分成三个部分:
		头部:thead
		主体:tbody
		底部:tfoot

- 表格的样式
	border-spacing:指定边框之间的距离
	border-collapse:collapse;设置边框的合并

	- 如果表格中没有使用tbody而是直接使用tr,那么浏览器会自动创建一个tbody,并且将全部tr都放到tbody
	- tr不是table的子元素

	- 默认情况下元素在td中是垂直居中的,可以通过vertical-align来调整
	- 将元素设置为单元格
		display: table-cell;
		vertical-align: middle;
			

<br></br>

表单

- 表单在我们的现实生活中用于提交数据
- 在网页中也可以使用表单,网页中的表单用于将本地的数据提交给远程的服务器

- 使用form标签来创建一个表单
- form的属性:
	action:指定表单要提交的服务器的地址


- 表单项
	- 文本框(<input type="text" name="username">):
		注意:数据要提交到服务器中,必须要为元素指定一个name属性值
	
	-	密码框(<input type="passward" name="userword">)
	-	单选按钮(<input type="radio" name="名字">):
		像这种选择器,必须要指定一个value属性,value属性最终会作为用户的填写的值传递给服务器
	-	多选框(<input type="checkbox" name="名字">)
	-	下拉列表(<select name="名">
					<option value="值1">选项一</option>
					<option selected(默认选中) value="值2">选项二</option>
				</select>)
	-	提交按钮(<input type="submit" value="值">)
	-	重置按钮(<input type="reset">)
	-	普通按钮(<input type="button" value="值">)

	- 按钮中的属性
		- autocomplete="on/off" 开启/关闭自动补全
		- readonly 将表单项设置为只读,数据会提交
		- disabled 将表单项设置为禁用,数据不会提交
		- autoforce 设置表单项自动获取焦点		

默认样式
	- 通常情况下,浏览器都会为元素设置一些默认样式
	- 默认样式的存在会影响到页面的布局
		通常情况下编写网页时必须要去除浏览器到默认样式(pc端端页面)

	-重置样式表,专门用来对浏览器到样式进行重置的
		reset.css 直接去除来浏览器到默认样式
		normalize.css 对默认样式进行了统一
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值