共计 15502 个字符,预计需要花费 39 分钟才能阅读完成。
回顾上一节 HTML 思维导图
CSS 课程目标
学会使用 CSS 选择器
熟记 CSS 样式和外观属性
熟练掌握 CSS 各种选择器
熟练掌握 CSS 各种选择器
熟练掌握 CSS 三种显示模式
熟练掌握 CSS 背景属性
熟练掌握 CSS 三大特性
熟练掌握 CSS 盒子模型
熟练掌握 CSS 浮动
10. 熟练掌握 CSS 定位 11. 熟练掌握 CSS 高级技巧强化 CSS
CSS 的发展历程
从 HTML 被发明开始,样式就以各种形式存在。不同的浏览器结合它们各自的样式语言为用户提供页面效果的控制。最初的 HTML 只包含很少的显示属性。
随着 HTML 的成长,为了满足页面设计者的要求,HTML 添加了很多显示功能。但是随着这些功能的增加,HTML 变的越来越杂乱,而且 HTML 页面也越来越臃肿。于是 CSS 便诞生了。
CSS 初识
CSS(Cascading Style Sheets) 美化样式
CSS 通常称为 CSS 样式表或层叠样式表(级联样式表),主要用于设置 HTML 页面中的文本内容(字体、大小、对齐方式等)、图片的外形(宽高、边框样式、边距等)以及版面的布局等外观显示样式。
CSS 以 HTML 为基础,提供了丰富的功能,如字体、颜色、背景的控制及整体排版等,而且还可以针对不同的浏览器设置不同的样式。
引入 CSS 样式表(书写位置)
CSS 可以写到那个位置?是不是一定写到 html 文件里面呢?
内部样式表
内嵌式是将 CSS 代码集中写在 HTML 文档的 head 头部标签中,并且用 style 标签定义,其基本语法格式如下:
<head>
<style type=”text/CSS”>
选择器 {属性 1: 属性值 1; 属性 2: 属性值 2; 属性 3: 属性值 3;}
</style>
</head>
语法中,style 标签一般位于 head 标签中 title 标签之后,也可以把他放在 HTML 文档的任何地方。
type=”text/CSS” 在 html5 中可以省略,写上也比较符合规范,所以这个地方可以写也可以省略。
行内式(内联样式)
内联样式,又有人称行内样式、行间样式、内嵌样式。是通过标签的 style 属性来设置元素的样式,其基本语法格式如下:
< 标签名 style=” 属性 1: 属性值 1; 属性 2: 属性值 2; 属性 3: 属性值 3;”> 内容 </ 标签名 >
语法中 style 是标签的属性,实际上任何 HTML 标签都拥有 style 属性,用来设置行内式。其中属性和值的书写规范与 CSS 样式规则相同,行内式只对其所在的标签及嵌套在其中的子标签起作用。
外部样式表(外链式)
链入式是将所有的样式放在一个或多个以.CSS 为扩展名的外部样式表文件中,通过 link 标签将外部样式表文件链接到 HTML 文档中,其基本语法格式如下:
<head>
<link href=”CSS 文件的路径 ” rel=”stylesheet” />
</head>
注意:link 是个单标签哦!!!
该语法中,link 标签需要放在 head 头部标签中,并且必须指定 link 标签的三个属性,具体如下:
href:定义所链接外部样式表文件的 URL,可以是相对路径,也可以是绝对路径。type:定义所链接文档的类型,在这里需要指定为“text/CSS”,表示链接的外部文件为 CSS 样式表。rel:定义当前文档与被链接文档之间的关系,在这里需要指定为“stylesheet”,表示被链接的文档是一个样式表文件。
三种样式表总结(位置)
CSS 样式规则
使用 HTML 时,需要遵从一定的规范。CSS 亦如此,要想熟练地使用 CSS 对网页进行修饰,首先需要了解 CSS 样式规则,具体格式如下:
在上面的样式规则中:
1. 选择器用于指定 CSS 样式作用的 HTML 对象,花括号内是对该对象设置的具体样式。2. 属性和属性值以“键值对”的形式出现。3. 属性是对指定的对象设置的样式属性,例如字体大小、文本颜色等。4. 属性和属性值之间用英文“:”连接。5. 多个“键值对”之间用英文“;”进行区分。可以用段落 和 表格的对齐的演示。
选择器(重点)
要想将 CSS 样式应用于特定的 HTML 元素,首先需要找到该目标元素。在 CSS 中,执行这一任务的样式规则部分被称为选择器(选择符)。
CSS 基础选择器
标签选择器(元素选择器)
标签选择器是指用 HTML 标签名称作为选择器,按标签名称分类,为页面中某一类标签指定统一的 CSS 样式。其基本语法格式如下:
标签名{属性 1: 属性值 1; 属性 2: 属性值 2; 属性 3: 属性值 3;} 或者元素名{属性 1: 属性值 1; 属性 2: 属性值 2; 属性 3: 属性值 3;}
标签选择器最大的优点是能快速为页面中同类型的标签统一样式,同时这也是他的缺点,不能设计差异化样式。
标签选择器 可以把某一类标签全部选择出来 div span
类选择器
类选择器使用“.”(英文点号)进行标识,后面紧跟类名,其基本语法格式如下:. 类名 {属性 1: 属性值 1; 属性 2: 属性值 2; 属性 3: 属性值 3;} 标签调用的时候用 class=“类名”即可。
类选择器最大的优势是可以为元素对象定义单独或相同的样式。可以选择一个或者多个标签
小技巧:1. 长名称或词组可以使用中横线来为选择器命名。2. 不建议使用“_”下划线来命名 CSS 选择器。
输入的时候少按一个 shift 键; 浏览器兼容问题 (比如使用_tips 的选择器命名,在 IE6 是无效的)能良好区分 JavaScript 变量命名(JS 变量命名是用“_”)
3. 不要纯数字、中文等命名,尽量使用英文字母来表示。
案例:
<head>
<meta charset=”utf-8″>
<style>
span {
font-size: 100px;
}
.blue {
color: blue;
}
.red {
color: red;
}
.orange {
color: orange;
}
.green {
color: green;
}
</style>
</head>
<body>
<span class=”blue”>G</span>
<span class=”red”>o</span>
<span class=”orange”>o</span>
<span class=”blue”>g</span>
<span class=”green”>l</span>
<span class=”red”>e</span>
</body>
多类名选择器
我们可以给标签指定多个类名,从而达到更多的选择目的。注意:
样式显示效果跟 HTML 元素中的类名先后顺序没有关系, 受 CSS 样式书写的上下顺序有关。
各个类名中间用空格隔开。
多类名选择器在后期布局比较复杂的情况下,还是较多使用的。
<div class=”pink fontWeight font20″> 亚瑟 </div>
<div class=”font20″> 刘备 </div>
<div class=”font14 pink”> 安其拉 </div>
<div class=”font14″> 貂蝉 </div>
id 选择器
id 选择器使用“#”进行标识,后面紧跟 id 名,其基本语法格式如下:
#id 名{属性 1: 属性值 1; 属性 2: 属性值 2; 属性 3: 属性值 3;}
该语法中,id 名即为 HTML 元素的 id 属性值,大多数 HTML 元素都可以定义 id 属性,元素的 id 值是唯一的,只能对应于文档中某一个具体的元素。
用法基本和类选择器相同。
id 选择器和类选择器区别
W3C 标准规定,在同一个页面内,不允许有相同名字的 id 对象出现,但是允许相同名字的 class。
类选择器(class)好比人的名字,是可以多次重复使用的,比如 张伟 王伟 李伟 李娜
id 选择器 好比人的身份证号码,全中国是唯一的,不得重复。只能使用一次。
d 选择器和类选择器最大的不同在于 使用次数上。
通配符选择器
通配符选择器用“*”号表示,他是所有选择器中作用范围最广的,能匹配页面中所有的元素。其基本语法格式如下:
* {属性 1: 属性值 1; 属性 2: 属性值 2; 属性 3: 属性值 3;}
例如下面的代码,使用通配符选择器定义 CSS 样式,清除所有 HTML 标记的默认边距。
* {
margin: 0; /* 定义外边距 */
padding: 0; /* 定义内边距 */
}
注意:
这个通配符选择器,就像我们的电影明星中的梦中情人,想想它就好了,但是它不会和你过日子。
CSS 字体样式属性
font-size: 字号大小
font-size 属性用于设置字号,该属性的值可以使用相对长度单位,也可以使用绝对长度单位。其中,相对长度单位比较常用,推荐使用像素单位 px,绝对长度单位使用较少。具体如下:
font-family: 字体
font-family 属性用于设置字体。网页中常用的字体有宋体、微软雅黑、黑体等,例如将网页中所有段落文本的字体设置为微软雅黑,可以使用如下 CSS 样式代码:
p{font-family:” 微软雅黑 ”;}
可以同时指定多个字体,中间以逗号隔开,表示如果浏览器不支持第一个字体,则会尝试下一个,直到找到合适的字体。
常用技巧:
现在网页中普遍使用 14px+。
尽量使用偶数的数字字号。ie6 等老式浏览器支持奇数会有 bug。
各种字体之间必须使用英文状态下的逗号隔开。
中文字体需要加英文状态下的引号,英文字体一般不需要加引号。当需要设置英文字体时,英文字体名必须位于中文字体名之前。
如果字体名中包含空格、#、$ 等符号,则该字体必须加英文状态下的单引号或双引号,例如 font-family: “Times New Roman”;。
尽量使用系统默认字体,保证在任何用户的浏览器中都能正确显示。
CSS Unicode 字体
font-weight: 字体粗细
字体加粗除了用 b 和 strong 标签之外,可以使用 CSS 来实现,但是 CSS 是没有语义的。
font-weight 属性用于定义字体的粗细,其可用属性值:normal、bold、bolder、lighter、100~900(100 的整数倍)。小技巧:数字 400 等价于 normal,而 700 等价于 bold。但是我们更喜欢用数字来表示。
font-style: 字体风格
字体倾斜除了用 i 和 em 标签之外,可以使用 CSS 来实现,但是 CSS 是没有语义的。
font-style 属性用于定义字体风格,如设置斜体、倾斜或正常字体,其可用属性值如下:
normal:默认值,浏览器会显示标准的字体样式。
italic:浏览器会显示斜体的字体样式。
oblique:浏览器会显示倾斜的字体样式。小技巧:平时我们很少给文字加斜体,反而喜欢给斜体标签(em,i)改为普通模式。
font: 综合设置字体样式 (重点)
font 属性用于对字体样式进行综合设置,其基本语法格式如下:
选择器{font: font-style font-weight font-size/line-height font-family;}
使用 font 属性时,必须按上面语法格式中的顺序书写,不能更换顺序,各个属性以空格隔开。
注意:其中不需要设置的属性可以省略(取默认值),但必须保留 font-size 和 font-family 属性,否则 font 属性将不起作用。
CSS 外观属性
color: 文本颜色
color 属性用于定义文本的颜色,其取值方式有如下 3 种:
1. 预定义的颜色值,如 red,green,blue 等。
2. 十六进制,如 #FF0000,#FF6600,#29D794 等。实际工作中,十六进制是最常用的定义颜色的方式。
3.RGB 代码,如红色可以表示为 rgb(255,0,0)或 rgb(100%,0%,0%)。
需要注意的是,如果使用 RGB 代码的百分比颜色值,取值为 0 时也不能省略百分号,必须写为 0%。
line-height: 行间距
ine-height 属性用于设置行间距,就是行与行之间的距离,即字符的垂直间距,一般称为行高。line-height 常用的属性值单位有三种,分别为像素 px,相对值 em 和百分比 %,实际工作中使用最多的是像素 px
一般情况下,行距比字号大 7.8 像素左右就可以了。
text-align: 水平对齐方式
text-align 属性用于设置文本内容的水平对齐,相当于 html 中的 align 对齐属性。其可用属性值如下:
left:左对齐(默认值)
right:右对齐
center:居中对齐
text-indent: 首行缩进
text-indent 属性用于设置首行文本的缩进,其属性值可为不同单位的数值、em 字符宽度的倍数、或相对于浏览器窗口宽度的百分比 %,允许使用负值, 建议使用 em 作为设置单位。
1em 就是一个字的宽度 如果是汉字的段落,1em 就是一个汉字的宽度
text-decoration 文本的装饰
text-decoration 通常我们用于给链接修改装饰效果
开发者工具(chrome)
此工具是我们的必备工具,以后代码出了问题,我们首先第一反应就是:
“按 F12”或者是“shift+ctrl+i”打开 开发者工具。
菜单:右击网页空白出 — 查看 小技巧:
ctrl+ 滚轮 可以 放大开发者工具代码大小。
左边是 HTML 元素结构 右边是 CSS 样式。
右边 CSS 样式可以改动数值和颜色查看更改后效果。
CSS 复合选择器
复合选择器是由两个或多个基础选择器,通过不同的方式组合而成的, 目的是为了可以选择更准确更精细的目标元素标签。
交集选择器
交集选择器由两个选择器构成,其中第一个为标签选择器,第二个为 class 选择器,两个选择器之间不能有空格,如 h3.special。
记忆技巧:交集选择器 是 并且的意思。即 … 又 … 的意思
比如:p.one 选择的是:类名为 .one 的 段落标签。
用的相对来说比较少,不太建议使用。
并集选择器
并集选择器(CSS 选择器分组)是各个选择器通过逗号连接而成的,任何形式的选择器(包括标签选择器、class 类选择器 id 选择器等),都可以作为并集选择器的一部分。如果某些选择器定义的样式完全相同,或部分相同,就可以利用并集选择器为它们定义相同的 CSS 样式。
记忆技巧:
并集选择器 和 的意思,就是说,只要逗号隔开的,所有选择器都会执行后面样式。
比如 .one, p , #test {color: #F00;} 表示 .one 和 p 和 #test 这三个选择器都会执行颜色为红色。通常用于集体声明。
后代选择器
后代选择器又称为包含选择器,用来选择元素或元素组的后代,其写法就是把外层标签写在前面,内层标签写在后面,中间用空格分隔。当标签发生嵌套时,内层标签就成为外层标签的后代。子孙后代都可以这么选择。或者说,它能选择任何包含在内 的标签。
子元素选择器
子元素选择器只能选择作为某元素子元素的元素。其写法就是把父级标签写在前面,子级标签写在后面,中间跟一个 进行连接,注意,符号左右两侧各保留一个空格。
比如:.demo > h3 {color: red;} 说明 h3 一定是 demo 亲儿子。demo 元素包含着 h3。
伪类选择器
伪类选择器用于向某些选择器添加特殊的效果。比如给链接添加特殊效果,比如可以选择 第 1 个,第 n 个元素。
为了和我们刚才学的类选择器相区别,类选择器是一个点 比如 .demo {} 而我们的伪类 用 2 个点 就是 冒号 比如 :link{}
链接伪类选择器
:link / 未访问的链接 /
:visited / 已访问的链接 /
:hover / 鼠标移动到链接上 /
:active / 选定的链接 / 注意写的时候,他们的顺序尽量不要颠倒 按照 lvha 的顺序。love hate 爱上了讨厌 记忆法 或者 lv 包包 非常 hao
a {/* a 是标签选择器 所有的链接 */
font-weight: 700;
font-size: 16px;
color: gray;
}
a:hover {/* :hover 是链接伪类选择器 鼠标经过 */
color: red; /* 鼠标经过的时候,由原来的 灰色 变成了红色 */
}
CSS 注释
CSS 规则是使用 / 需要注释的内容 / 进行注释的,即在需要注释的内容前使用“/”标记开始注释,在内容的结尾使用“/”结束。
例如:p {font-size: 14px; / 所有的字体是 14 像素大小 /}
标签显示模式(display)
HTML 标签一般分为块标签和行内标签两种类型,它们也称块元素和行内元素。具体如下:
块级元素(block-level)
每个块元素通常都会独自占据一整行或多整行,可以对其设置宽度、高度、对齐等属性,常用于网页布局和网页结构的搭建。
常见的块元素有 <h1>~<h6>、<p>、<div>、<ul>、<ol>、<li> 等,其中 <div> 标签是最典型的块元素。
块级元素的特点:
(1)总是从新行开始
(2)高度,行高、外边距以及内边距都可以控制。
(3)宽度默认是容器的 100%
(4)可以容纳内联元素和其他块元素。
行内元素(inline-level)
行内元素(内联元素)不占有独立的区域,仅仅靠自身的字体大小和图像尺寸来支撑结构,一般不可以设置宽度、高度、对齐等属性,常用于控制页面中文本的样式。
常见的行内元素有 <a>、<strong>、<b>、<em>、<i>、<del>、<s>、<ins>、<u>、<span> 等,其中 <span> 标签最典型的行内元素。
行内元素的特点:
(1)和相邻行内元素在一行上。
(2)高、宽无效,但水平方向的 padding 和 margin 可以设置,垂直方向的无效。
(3)默认宽度就是它本身内容的宽度。
(4)行内元素只能容纳文本或则其他行内元素。(a 特殊)
注意:
只有 文字才 能组成段落 因此 p 里面不能放块级元素,同理还有这些标签 h1,h2,h3,h4,h5,h6,dt,他们都是文字类块级标签,里面不能放其他块级元素。
链接里面不能再放链接。
块级元素和行内元素区别
块级元素的特点:(1)总是从新行开始(2)高度,行高、外边距以及内边距都可以控制。(3)宽度默认是容器的 100%(4)可以容纳内联元素和其他块元素。
行内元素的特点:(1)和相邻行内元素在一行上。(2)高、宽无效,但水平方向的 padding 和 margin 可以设置,垂直方向的无效。(3)默认宽度就是它本身内容的宽度。(4)行内元素只能容纳文本或则其他行内元素。
行内块元素(inline-block)
在行内元素中有几个特殊的标签——<img />、<input />、<td>,可以对它们设置宽高和对齐属性,有些资料可能会称它们为行内块元素。
行内块元素的特点:(1)和相邻行内元素(行内块)在一行上, 但是之间会有空白缝隙。(2)默认宽度就是它本身内容的宽度。(3)高度,行高、外边距以及内边距都可以控制。
标签显示模式转换 display
块转行内:display:inline;
行内转块:display:block;
块、行内元素转换为行内块:display: inline-block;
CSS 书写规范
开始就形成良好的书写规范,是你专业化的开始。
空格规范
【强制】选择器 与 {之间必须包含空格。
示例:.selector {}
【强制】属性名 与之后的 : 之间不允许包含空格,: 与 属性值 之间必须包含空格。
示例:
font-size: 12px;
选择器规范
【强制】当一个 rule 包含多个 selector 时,每个选择器声明必须独占一行。
示例:
/* good */
.post,
.page,
.comment {
line-height: 1.5;
}
/* bad */
.post, .page, .comment {
line-height: 1.5;
}
【建议】选择器的嵌套层级应不大于 3 级,位置靠后的限定条件应尽可能精确。
示例:
/* good */
#username input {}
.comment .avatar {}
/* bad */
.page .header .login #username input {}
.comment div * {}
属性规范
【强制】属性定义必须另起一行。
示例:
/* good */
.selector {
margin: 0;
padding: 0;
}
/* bad */
.selector {margin: 0; padding: 0;}
【强制】属性定义后必须以分号结尾。
示例:
/* good */
.selector {
margin: 0;
}
/* bad */
.selector {
margin: 0
}
CSS 三大特性
层叠 继承 优先级 是我们学习 CSS 必须掌握的三个特性。
CSS 层叠性
个属性通过两个相同选择器设置到同一个元素上,那么这个时候一个属性就会将另一个属性层叠掉
比如先给某个标签指定了内部文字颜色为红色,接着又指定了颜色为蓝色,此时出现一个标签指定了相同样式不同值的情况,这就是样式冲突。
一般情况下,如果出现样式冲突,则会按照 CSS 书写的顺序,以最后的样式为准。
样式冲突,遵循的原则是就近原则。那个样式离着结构近,就执行那个样式。
样式不冲突,不会层叠
CSS 继承性
所谓继承性是指书写 CSS 样式表时,子标签会继承父标签的某些样式,如文本颜色和字号。想要设置一个可继承的属性,只需将它应用于父元素即可。
简单的理解就是:子承父业。
注意:恰当地使用继承可以简化代码,降低 CSS 样式的复杂性。子元素可以继承父元素的样式(text-,font-,line- 这些元素开头的都可以继承,以及 color 属性)
CSS 优先级
定义 CSS 样式时,经常出现两个或更多规则应用在同一元素上,这时就会出现优先级的问题。
在考虑权重时,初学者还需要注意一些特殊的情况,具体如下:
继承样式的权重为 0。即在嵌套结构中,不管父元素样式的权重多大,被子元素继承时,他的权重都为 0,也就是说子元素定义的样式会覆盖继承来的样式。
行内样式优先。应用 style 属性的元素,其行内样式的权重非常高,可以理解为远大于 100。总之,他拥有比上面提高的选择器都大的优先级。
权重相同时,CSS 遵循就近原则。也就是说靠近元素的样式具有最大的优先级,或者说排在最后的样式优先级最大。
CSS 定义了一个!important 命令,该命令被赋予最大的优先级。也就是说不管权重如何以及样式位置的远近,!important 都具有最大优先级。
CSS 的特性
总结优先级:
使用了 !important 声明的规则。
内嵌在 HTML 元素的 style 属性里面的声明。
使用了 ID 选择器的规则。
使用了类选择器、属性选择器、伪元素和伪类选择器的规则。
使用了元素选择器的规则。
只包含一个通用选择器的规则。
同一类选择器则遵循就近原则。
总结:权重是优先级的算法,层叠是优先级的表现
CSS 背景(background)
CSS 可以添加背景颜色和背景图片,以及来进行图片设置。
背景图片(image)
语法:
background-image : none | url (url)
参数:none : 无背景图(默认的)url : 使用绝对或相对地址指定背景图像 background-image 属性允许指定一个图片展示在背景中(只有 CSS3 才可以多背景)可以和 background-color 连用。如果图片不重复地话,图片覆盖不到地地方都会被背景色填充。如果有背景图片平铺,则会覆盖背景颜色。
小技巧:我们提倡 背景图片后面的地址,url 不要加引号。
背景平铺(repeat)
语法:
background-repeat : repeat | no-repeat | repeat-x | repeat-y
参数:
repeat : 背景图像在纵向和横向上平铺(默认的)
no-repeat : 背景图像不平铺
repeat-x : 背景图像在横向上平铺
repeat-y : 背景图像在纵向平铺
设置背景图片时,默认把图片在水平和垂直方向平铺以铺满整个元素。
repeat-x : 背景图像在横向上平铺
repeat-y : 背景图像在纵向平铺
背景位置(position)
语法:
background-position : length || length
background-position : position || position
参数:length : 百分数 | 由浮点数字和单位标识符组成的长度值。请参阅长度单位 position : top | center | bottom | left | center | right
说明:设置或检索对象的背景图像位置。必须先指定 background-image 属性。默认值为:(0% 0%)。如果只指定了一个值,该值将用于横坐标。纵坐标将默认为 50%。第二个值将用于纵坐标。
注意:
position 后面是 x 坐标和 y 坐标。可以使用方位名词或者 精确单位。
如果和精确单位和方位名字混合使用,则必须是 x 坐标在前,y 坐标后面。比如 background-position: 15px top; 则 15px 一定是 x 坐标 top 是 y 坐标。
实际工作用的最多的,就是背景图片居中对齐了。
背景附着
语法:
background-attachment : scroll | fixed
参数:scroll : 背景图像是随对象内容滚动 fixed : 背景图像固定 说明:设置或检索背景图像是随对象内容滚动还是固定的。
背景简写
background 属性的值的书写顺序官方并没有强制标准的。为了可读性,建议大家如下写:
background: 背景颜色 背景图片地址 背景平铺 背景滚动 背景位置
background: transparent url(image.jpg) repeat-y scroll 50% 0 ;
背景透明(CSS3)
CSS3 支持背景半透明的写法语法格式是:
background: rgba(0,0,0,0.3);
最后一个参数是 alpha 透明度 取值范围 0~1 之间 注意:背景半透明是指盒子背景半透明,盒子里面的内容不收影响。
导航栏案例
使用技巧:在一行内的盒子内,我们设定行高等于盒子的高度,就可以使文字垂直居中。
<head>
<meta charset=”utf-8″>
<style>
body {
background-color: #000;
}
a {
width: 200px;
height: 50px;
/* background-color: orange; */
display: inline-block; /* 把 a 行内元素转换为行内块元素 */
text-align: center; /* 文字水平居中 */
line-height: 50px; /* 我们设定行高等于盒子的高度,就可以使文字垂直居中 */
color: #fff;
font-size: 22px;
text-decoration: none; /* 取消下划线 文本装饰 */
}
a:hover {/* 鼠标经过 给我们的链接添加背景图片 */
background: url(images/h.png) no-repeat;
}
</style>
</head>
<body>
<a href=”#”> 专区说明 </a>
<a href=”#”> 申请资格 </a>
<a href=”#”> 兑换奖励 </a>
<a href=”#”> 下载游戏 </a>
</body>
盒子模型(CSS 重点)
其实,CSS 就三个大模块:盒子模型、浮动、定位,其余的都是细节。要求这三部分,无论如何也要学的非常精通。
所谓盒子模型就是把 HTML 页面中的元素看作是一个矩形的盒子,也就是一个盛装内容的容器。每个矩形都由元素的内容、内边距(padding)、边框(border)和外边距(margin)组成。
看透网页布局的本质把网页元素比如文字图片等等,放入盒子里面,然后利用 CSS 摆放盒子的过程,就是网页布局。
盒子模型(Box Model)
盒子边框(border)
边框就是那层皮。橘子皮、柚子皮、橙子皮。
语法:
border : border-width || border-style || border-color
边框属性—设置边框样式(border-style)边框样式用于定义页面中边框的风格,常用属性值如下:
none:没有边框即忽略所有边框的宽度(默认值)
solid:边框为单实线(最为常用的)
dashed:边框为虚线
dotted:边框为点线
double:边框为双实线
盒子边框写法总结表
表格的细线边框
以前学过的 html 表格边框很粗,这里只需要 CSS 一句话就可以美观起来。让我们真的相信,CSS 就是我们的白马王子(白雪公主)。
table{border-collapse:collapse;} collapse 单词是合并的意思
border-collapse:collapse; 表示边框合并在一起。
圆角边框(CSS3)
从此以后,我们的世界不只有矩形。radius 半径(距离)
语法格式:
border-radius: 左上角 右上角 右下角 左下角;
内边距(padding)
padding 属性用于设置内边距。是指 边框与内容之间的距离。
padding-top: 上内边距 padding-right: 右内边距 padding-bottom: 下内边距 padding-left: 左内边距
外边距(margin)
margin 属性用于设置外边距。设置外边距会在元素之间创建“空白”,这段空白通常不能放置其他内容。
margin-top: 上外边距 margin-right: 右外边距 margin-bottom: 下外边距 margin-left: 上外边距 margin: 上外边距 右外边距 下外边距 左外边取值顺序跟内边距相同。
外边距实现盒子居中可以让一个盒子实现水平居中,需要满足一下两个条件:
必须是块级元素。
盒子必须指定了宽度(width)
然后就给左右的外边距都设置为 auto,就可使块级元素水平居中。实际工作中常用这种方式进行网页布局,示例代码如下:
.header{width:960px; margin:0 auto;}
文字盒子居中图片和背景区别
文字水平居中是 text-align: center
盒子水平居中 左右 margin 改为 auto
text-align: center; /* 文字居中水平 */
margin: 10px auto; /* 盒子水平居中 左右 margin 改为 auto 就阔以了 */
插入图片 我们用的最多 比如产品展示类
背景图片我们一般用于小图标背景 或者 超大背景图片
section img {
width: 200px;/* 插入图片更改大小 width 和 height */
height: 210px;
margin-top: 30px; /* 插入图片更改位置 可以用 margin 或 padding 盒模型 */
margin-left: 50px; /* 插入当图片也是一个盒子 */
}
aside {
width: 400px;
height: 400px;
border: 1px solid purple;
background: #fff url(images/sun.jpg) no-repeat;
background-size: 200px 210px; /* 背景图片更改大小只能用 background-size */
background-position: 30px 50px; /* 背景图片更该位置 我用 background-position */
}
清除元素的默认内外边距
为了更方便地控制网页中的元素,制作网页时,可使用如下代码清除元素的默认内外边距:
* {
padding:0; /* 清除内边距 */
margin:0; /* 清除外边距 */
}
注意:行内元素是只有左右外边距的,是没有上下外边距的。内边距,在 ie6 等低版本浏览器也会有问题。我们尽量不要给行内元素指定上下的内外边距就好了。
content 宽度和高度
使用宽度属性 width 和高度属性 height 可以对盒子的大小进行控制。width 和 height 的属性值可以为不同单位的数值或相对于父元素的百分比 %,实际工作中最常用的是像素值。大多数浏览器,如 Firefox、IE6 及以上版本都采用了 W3C 规范,符合 CSS 规范的盒子模型的总宽度和总高度的计算原则是:
/* 外盒尺寸计算(元素空间尺寸)*/
Element 空间高度 = content height + padding + border + margin
Element 空间宽度 = content width + padding + border + margin
/* 内盒尺寸计算(元素实际大小)*/
Element Height = content height + padding + border(Height 为内容高度)
Element Width = content width + padding + border(Width 为内容宽度)
注意:1、宽度属性 width 和高度属性 height 仅适用于块级元素,对行内元素无效(img 标签和 input 除外)。2、计算盒子模型的总高度时,还应考虑上下两个盒子垂直外边距合并的情况。3、如果一个盒子没有给定宽度 / 高度或者继承父亲的宽度 / 高度,则 padding 不会影响本盒子大小。
盒子模型布局稳定性
开始学习盒子模型,同学们最大的困惑就是,分不清内外边距的使用,什么情况下使用内边距,什么情况下使用外边距?
答案是:其实他们大部分情况下是可以混用的。就是说,你用内边距也可以,用外边距也可以。你觉得哪个方便,就用哪个。
但是,总有一个最好用的吧,我们根据稳定性来分,建议如下:
按照 优先使用 宽度(width)其次 使用内边距(padding)再次 外边距(margin)。
width > padding > margin
原因:
margin 会有外边距合并 还有 ie6 下面 margin 加倍的 bug(讨厌)所以最后使用。
padding 会影响盒子大小,需要进行加减计算(麻烦)其次使用。
width 没有问题(嗨皮)我们经常使用宽度剩余法 高度剩余法来做。
盒子阴影
语法格式:
box-shadow: 水平阴影 垂直阴影 模糊距离 阴影尺寸 阴影颜色 内 / 外阴影;
前两个属性是必须写的。其余的可以省略。
外阴影 (outset) 但是不能写 默认 想要内阴影 inset
div {
width: 200px;
height: 200px;
border: 10px solid red;
/* box-shadow: 5px 5px 3px 4px rgba(0, 0, 0, .4); */
/* box-shadow: 水平位置 垂直位置 模糊距离 阴影尺寸(影子大小)阴影颜色 内 / 外阴影;*/
box-shadow: 0 15px 30px rgba(0, 0, 0, .4);
}
浮动(float)
前面我们说过,网页布局的核心,就是用 CSS 来摆放盒子位置。如何把盒子摆放到合适的位置?
CSS 的定位机制有 3 种:普通流(标准流)、浮动和定位。
什么是浮动?
元素的浮动是指设置了浮动属性的元素会脱离标准普通流的控制,移动到其父元素中指定位置的过程。
在 CSS 中,通过 float 属性来定义浮动,其基本语法格式如下:
选择器{float: 属性值;}
布局流程
为了提高网页制作的效率,布局时通常需要遵守一定的布局流程,具体如下:
1、确定页面的版心(可视区)。2、分析页面中的行模块,以及每个行模块中的列模块。3、制作 HTML 结构。4、CSS 初始化,然后开始运用盒子模型的原理,通过 DIV+CSS 布局来控制网页的各个模块。一列固定宽度且居中
最普通的,最为常用的结构
清除浮动的方法
其实本质叫做闭合浮动更好一些, 记住,清除浮动就是把浮动的盒子圈到里面,让父盒子闭合出口和入口不让他们出来影响其他元素。
在 CSS 中,clear 属性用于清除浮动,其基本语法格式如下:
选择器{clear: 属性值;}
定位(position)
元素的定位属性主要包括定位模式和边偏移两部分 1、边偏移
也就说,以后定位要和这边偏移搭配使用了,比如 top: 100px; left: 30px; 等等 2、定位模式 (定位的分类) 在 CSS 中,position 属性用于定义元素的定位模式,其基本语法格式如下:选择器{position: 属性值;}position 属性的常用值
绝对定位
当 position 属性的取值为 absolute 时,可以将元素的定位模式设置为绝对定位。
四种定位总结
CSS 高级技巧
所谓的界面样式,就是更改一些用户操作样式,比如 更改用户的鼠标样式,表单轮廓等。但是比如滚动条的样式改动受到了很多浏览器的抵制,因此我们就放弃了。防止表单域拖拽
鼠标样式 cursor
设置或检索在对象上移动的鼠标指针采用何种系统预定义的光标形状。
cursor : default 小白 | pointer 小手 | move 移动 | text 文本
鼠标放我身上查看效果哦:
<ul>
<li style=”cursor:default”> 我是小白 </li>
<li style=”cursor:pointer”> 我是小手 </li>
<li style=”cursor:move”> 我是移动 </li>
<li style=”cursor:text”> 我是文本 </li>
</ul>
尽量不要用 hand 因为 火狐不支持 pointer ie6 以上都支持的尽量用
轮廓 outline
是绘制于元素周围的一条线,位于边框边缘的外围,可起到突出元素的作用。
outline : outline-color ||outline-style || outline-width
但是我们都不关心可以设置多少,我们平时都是去掉的。
最直接的写法是:outline: 0; 或者 outline: none;
<input type=”text” style=”outline: 0;”/>
防止拖拽文本域 resize
resize:none 这个单词可以防止 火狐 谷歌等浏览器随意的拖动 文本域。
右下角可以拖拽:
<textarea></textarea>
右下角不可以拖拽:
<textarea style=”resize: none;”></textarea>
以前我们讲过让带有宽度的块级元素居中对齐,是 margin: 0 auto;
以前我们还讲过让文字居中对齐,是 text-align: center;
字体设计推荐网站
http://icomoon.io
icomoon 字库
IcoMoon 成立于 2011 年,推出的第一个自定义图标字体生成器,它允许用户选择他们所需要的图标,使它们成一字型。内容种类繁多,非常全面,唯一的遗憾是国外服务器,打开网速较慢。
推荐网站:http://www.iconfont.cn/ 阿里 icon font 字库
http://www.iconfont.cn/
这个是阿里妈妈 M2UX 的一个 icon font 字体图标字库,包含了淘宝图标库和阿里妈妈图标库。可以使用 AI 制作图标上传生成。一个字,免费,免费!!
fontello
http://fontello.com/
在线定制你自己的 icon font 字体图标字库,也可以直接从 GitHub 下载整个图标集,该项目也是开源的。
Font-Awesome
http://fortawesome.github.io/…
这是我最喜欢的字库之一了,更新比较快。目前已经有 369 个图标了。
Glyphicon Halflings
http://glyphicons.com/
这个字体图标可以在 Bootstrap 下免费使用。自带了 200 多个图标。
Icons8
https://icons8.com/
提供 PNG 免费下载,像素大能到 500PX 转换 ico 图标
我们可以自己做的图片,转换为 ico 图标,以便放到我们站点里面。http://www.bitbug.net/