一.CSS
css(汉译层叠样式表)WEB标准中的表现标准语言,表现标准语言在网页中主要对网页信息的显示进行控制,简单说就是如何修饰网页信息的显示样式。
二.CSS语法
1.语法:选择符{属性:属性值;属性;属性值;}
举例:div{width:500px; background:yellow; height:100px; border: solid red 1 px;}
说明:
(1)每个CSS样式由两部分组成,即选择符和声明,声明又分为属性和属性值;
(2)属性必须放在花括号中,属性与属性值用冒号链接。
(3)每条声明用分号结束。
(4)当一个属性有多个属性值得时候,属性值与属性值不分先后顺序。
(5)在书写样式过程中,空格、换行等操作不影响显示
2.div+css布局的优点
- (1)缩减页面代码,提高访问速度-代码减少,页面文件就会小,占用网络带宽就少,客户端打开速度就快,用户体验会更好
- (2)结构清晰,有利于seo-有利于搜索引擎优化-缩短改版时间-对网站的重构有很好的支持-弥补html语言的不足。
- (3)样式表能实现内容和样式的分量,方便团队开发。样式复用、方便网站的后期维护
三.CSS样式表的建立
CSS样式表分为三种:内部样式表(嵌套到页面中)、内联样式(行间样式,行内样式,嵌入式样式)、引用外部样式表文件
1.内部样式表语法:
2.内联样式语法:
<标签 style="属性: 属性值;属性: 属性值;">
举例:
3.引用外部样式表文件: 有两种方法
- 方法1:
注: 使用link元素导入外部样式表时,需将该元素写在文档头部,即
与之间。- 方法2:
注: @和import之间没有空格 url和小括号之间也没有空格; 必须结尾以分号结束;
link和import导入外部样式的区别:
- (1)本质上的差别:link属于XHTML标签,而@import完全是CSS提供的一种方式.link标签除了可以加载CSS外,还可以做很多其他的事情,比如定义RSS(是一种信息聚合的技术。
作用:是为了提供一种更为方便、高效的互联网信息的发布和共享,用更少的时间分享更多的信息。),定义rel连接属性等,@import就只能加载CSS。 - (2)加载顺序的差别:当一个页面被加载的时候(就是被浏览者浏览的时候),link引用的CSS会同时被加载,而@import引用的CSS会等到页面全部被下载完再被加载。所以有时候浏览@import加载CSS的页面时开始会没有样式。
- (3)兼容性的差别:@import是CSS2.1提出的,所以老的浏览器不支持,@import只在IE5以上的才能识别,而link标签无此问题。
- (4)使用dom控制样式时的差别:当使用javascript控制dom区改变样式的时候,只能使用link标签,因为@import不是dom可以控制的。
四.CSS选择符(选择器)
1.选择符表示要定义样式的对象,可以是元素本身,也可以是一类元素或者制定名称的元素。
2.CSS选择符包括4大类:类型选择符、class选择符、和特殊选择符;
3.常用的选择符有十种左右:类型选择符(标记选择器),id选择符,class选择符,通配符(*),群组选择符(集合选择器),包含选择符(后代选择器),伪类选择符,伪对象选择符
(1)元素选择符/类型选择符(element选择器) 语法: 元素名称{属性: 属性值;}
说明:
a:元素选择符就是以文档语言对象类型作为选择符,即使用结构中元素名称作为选择符。例如body、div、p、img、em、strong、span.....等。
b:所有的页面元素都可以作为选择符(不是绝对的);
用法:
a:若干想改变某个元素的默认样式时,可以使用类型选择符;
b:当统一文档某个元素的显示效果时,可以使用类型选择符;(2)id选择器 语法: #id名{属性: 属性值;}
说明:
a:当我们使用id选择符时,应该为每个元素定义一个id属性,如:
b:id选择符的语法格式是"#"加上自定义的id名。如:
#box{width:300px; height:300px}
c:起名时要取英文名,不能用关键字:(所有的标记和属性都是关键字)如: head、title标记。。。
d:一个id名称只能对应文档中一个具体的元素对象,因为id只能定义页面中某一个唯一的元素对象。
e:最大的用处:创建网页的外围结构
- (3)class选择器 语法: .class名{属性: 属性值;}
说明:
a:当我们使用类选择符时,应先为每个元素定义一个类名称。
b:用法:class选择符更适合定义一类样式。
c:类选择符的语法格式是:如:
- (4)*通配符 语法: {属性: 属性值;}
说明:
a:通配选择符的写法是"",其含义就是所有元素。
b:用法:常用来重置样式。如:
*{margin: 0; padding:0;}
- (5)群组选择器 语法: 选择符1,选择符2,选择符3,...{属性: 属性值;}
说明:
当有多个选择符应用相同的样式时,可以将选择符用","分隔的方式,合并为一组。如:
选择符1, 选择符2...{margin:0 auto;}元素居中。
- (6)包含选择器 语法:选择符1 选择符2{属性: 属性值;}
说明:
选择符1和选择符2用空格隔开,含义就是选择符1中包含的所有选择符2; - (7)伪类选择器(伪类选择符)
语法:
a:link{属性: 属性值;}超链接的初始状态;
a:visited{属性: 属性值;}超链接被访问后的状态;
a:hover{属性: 属性值;}鼠标悬停,即鼠标划过超链接时的
状态;
a:active{属性: 属性值;}超链接被激活时的状态,即鼠标按下时超链接的状态;
说明:
1.当这4个超链接伪类选择符联合使用时,应注意他们的顺序,正常顺序为: a:link,a:visited,a:hover,a:active,错误的顺序有时会使超链接的样式失效;
2.为了简化代码,可以把伪类选择符中相同的声明提出来放在a选择符中;例如:
a{color:red;} a:hover{color:green;}
表示超链接的三种状态都相同,只有鼠标划过变颜色。
3.当这4个超链接伪类选择符联合使用时,为了达到预期效果建议清除浏览器缓存或使用ie浏览器使用。(因为元素自身有缓存问题)
当我们使用伪类选择器时,4个联合使用时:
- 1.它们的顺序不能错;
- 2.要想达到预期效果,必须清除浏览器缓存
五.CSS样式表的优先级
1.样式表的作用域:行内样式的作用域是当前标签,内部样式的作用域是当前文件,外部样式表的作用域是有关联的所有文件。
2.样式表的优先级:内联样式表的优先级别最高。内部样式表与外部样式表的优先级和书写的顺序有关,后者写的优先级别高。
3.选择符的权重:css中用四位数字表示权重,权重的表达方式如:0,0,0,0
- (1)类型选择符的权重为0001
- (2)class选择符的权重为0010
- (3)id选择符的权重为0100
- (4)子选择符的权重为0000
- (5)属性选择符的权重为0010
- (6)伪类选择符的权重为0010
- (7)伪元素选择符的权重为0010
- (8)包含选择符的权重:包含的选择符权重值之和
- (9)内联样式的权重为1000
- (10)继承样式的权重为0000
权重的作用:
当不同选择符的样式设置有冲突的时候,高权重选择符的样式会覆盖低权重选择符的样式。
例如: p .demo的权重是1+10=11。
六.CSS的注释
/* 注释内容 */
七.建站流程图
作业
1.广告 字体大小 28px 颜色 白色 居中
2.导航
3.banner
4.content
5.hot
6.footer