第一章 html介绍
1-4 标签的语法
- 标签由英文尖括号<和>括起来,如<html>就是一个标签。
- html中的标签一般都是成对出现的,分开始标签和结束标签。结束标签比开始标签多了一个 /。
<p></p>
<div></div>
<span></span>
- 标签与标签之间是可以嵌套的,但先后顺序必须保持一致,如:<div>里嵌套<p>,那么</p>必须放在</div>的前面。如下图所示。
- HTML标签不区分大小写,<h1>和<H1>是一样的,但建议小写,因为大部分程序员都以小写为准。
1-5html文件基本结构
一个HTML文件是有自己固定的结构的。
<html>
<head>...</head>
<body>...</body>
</html>
- <html></html>称为根标签,所有的网页标签都在<html></html>中。
- <head> 标签用于定义文档的头部,它是所有头部元素的容器。
头部元素有<title>、<script>、 <style>、<link>、 <meta>等标签. - 在<body>和</body>标签之间的内容是网页的主要内容,如<h1>、<p>、<a>、<img>等网页内容标签,在这里的标签中的内容会在浏览器中显示出来。
1-6 head标签
head标签
定义:文档的头部描述了文档的各种属性和信息,包括文档的标题等。绝大多数文档头部包含的数据都不会真正作为内容显示给读者。
<head>
<title>...</title>
<meta>
<link>
<style>...</style>
<script>...</script>
</head>
title标签
定义:在<title>和</title>标签之间的文字内容是网页的标题信息,出现在浏览器的标题栏中。
作用:
1、用于告诉用户和搜索引擎这个网页的主要内容
2、搜索引擎可以通过网页标题,迅速的判断出网页的主题。
3、每个网页的内容都是不同的,每个网页都应该有一个独一无二的title。
<head>
<title>hello world</title>
</head>
1-7 代码注释
作用:帮助程序员标注代码的用途,过一段时间后再看你所编写的代码,就能很快想起这段代码的用途
优点:
1、方便程序员自己回忆起以前代码的用途
2、帮助其他程序员很快的读懂你的程序的功能,方便多人合作开发网页代码。
<!--注释文字 -->
第二章 认识标签
2-1 语义化
含义:明白每个标签的用途(在什么情况下使用此标签合理)
优点:
1、更容易被搜索引擎收录。
2、更容易让屏幕阅读器读出网页内容。
2-3 <p>标签(添加段落)
<p>段落文本</p>
注意:
1、每个段落都需要加<p>标签
2、<p>标签默认段前段后都会有空白,
2-4 <hx>标签(标题)
含义:文章的标题、栏目的标题,
标题标签一共有6个,
h1 —— 一级标题
h2 —— 二级标题
h3 —— 三级标题
h4 —— 四级标题
h5 ——五级标题
h6 —— 六级标题
注意:
1、依据重要性递减。<h1>是最高的等级。
2、标题标签的样式都会加粗,h1标签字号最大,h2标签字号相对h1要小,以此类推h6标签的字号最小。
<hx>标题文本</hx> (x为1-6)
<body>
<h1>一级标题</h1>
<h2>二级标题</h2>
<h3>三级标题</h3>
<h4>四级标题</h4>
<h5>五级标题</h5>
<h6>六级标题</h6>
</body>
2-5 <strong>和<em>标签(强调)
注意:
1、<em> 表示强调
浏览器中<em> 默认用斜体表示
2、<strong> 表示更强烈的强调。<strong> 用粗体表示。
两个标签相比,目前国内前端程序员更喜欢使用<strong>表示强调。
<em>需要强调的文本</em>
<strong>需要强调的文本</strong>
2-6 <span>标签(问文字设置单独样式)
作用:只是想为它设置和其它文字不同的样式(并不想让屏幕阅读器对文字加重音读出)
<span>文本</span>
2-7 <q>标签(短文本引用)
含义:引用别人的一句话
作用:在你的网页的文章里想引用某个作家的文字
注意:
1、不是作者自己的文字
2、不要引用的文本不用加双引号,浏览器会对q标签自动添加双引号。
<q>引用文本</q>
2-8 <blockquote>标签(长文本引用)
含义:在文章中引入大段某知名作家的文字
样式:浏览器对<blockquote>标签的解析是两边缩进样式
<blockquote>引用文本</blockquote>
2-9 br标签(分行显示文本)
作用:相当于word文档中的回车
注意:<br />标签是一个空标签,空标签只需要写一个开始标签,这样的标签有<br />、<hr />和<img />。
xhtml1.0写法:
<br />
html4.01写法:
<br>
2-10 空格
作用:在html代码中输入空格、回车都是没有作用的,必须单独输入代码
2-11 hr标签(水平横线)
作用:在信息展示时,有时会需要加一些用于分隔的横线,这样会使文章看起来整齐些。
注意:
- <hr />标签和<br />标签一样也是一个空标签,所以只有一个开始标签,没有结束标签。
- <hr />标签的在浏览器中的默认样式线条比较粗,颜色为灰色。
- 现在一般使用 xhtml1.0 的版本(其它标签也是),这种版本比较规范
html4.01版本 <hr>
xhtml1.0版本 <hr />
2-12 <address>标签(为网页加入地址信息)
含义:一般网页中会有一些网站的联系地址信息需要在网页中展示出来,这些联系地址信息如公司的地址就可以<address>标签。也可以定义一个地址(比如电子邮件地址)、签名或者文档的作者身份。
<address>联系地址信息</address>
<address>
本文的作者:<a href="mailto:lilian@imooc.com">lilian</a>
</address>
样式:在浏览器上显示的样式为斜体
2-13 <code>标签(加入一行代码)
含义:在介绍语言技术的网站中,当代码为一行代码时,可以使用<code>标签
<code>代码语言</code>
注意:如果是多行代码,可以使用<pre>标签。
2-14 <pre>标签(加入大段代码)
作用:预格式化的文本。被包围在 pre 元素中的文本通常会保留空格和换行符。
<pre>语言代码段</pre>
<pre>
var message="欢迎";
for(var i=1;i<=10;i++)
{
alert(message);
}
</pre>
注意:网页中预显示格式也可以使用它
第三章 认识标签2
3-1 <ul>标签(添加新闻信息列表)
含义:ul-li是没有前后顺序的信息列表。
<ul>
<li>信息</li>
<li>信息</li>
......
<ul>
样式:每项li前都自带一个圆点
3-2 <ol>标签(添加图书销售排行榜)
含义:网页中展示有前后顺序的信息列表
<ol>
<li>信息</li>
<li>信息</li>
......
</ol>
样式:每项<li>前都自带一个序号,序号默认从1开始
3-3 <div>标签(排版)
含义:以把一些独立的逻辑部分划分出来,放在一个<div>标签中,这个<div>标签的作用就相当于一个容器。
<div>…</div>
注意:确定逻辑部分:
什么是逻辑部分?它是页面上相互关联的一组元素。如网页中的独立的栏目版块,就是一个典型的逻辑部分。
3-4 <div>命名(逻辑清晰)
含义:为了使逻辑更加清晰,我们可以为这一个独立的逻辑部分设置一个名称,用id属性来为<div>提供唯一的名称
<div id="版块名称">…</div>
3-5 <table>标签(表格)
创建表格的四个元素:
table、tbody、tr、th、td
- <table>…</table>:整个表格以<table>标记开始、</table>标记结束。
- <tbody>…</tbody>:如果不加<thead><tbody><tfooter> , table表格加载完后才显示。加上这些表格结构, tbody包含行的内容下载完优先显示,不必等待表格结束后在显示,同时如果表格很长,用tbody分段,可以一部分一部分地显示。(通俗理解table 可以按结构一块块的显示,不在等整个表格加载完后显示。)
- <tr>…</tr>:表格的一行,所以有几对tr 表格就有几行。
- <td>…</td>:表格的一个单元格,一行中包含几对<td>...</td>,说明一行中就有几列。
- <th>…</th>:表格的头部的一个单元格,表格表头。
- 表格中列的个数,取决于一行中数据单元格的个数。
注意:表头,也就是th标签中的文本默认为粗体并且居中显示
3-6 用css样式,为表格加入边框
作用:Table 表格在没有添加 css 样式之前,是没有边框的。加边框便于对合并单元格的理解。
<style type="text/css">
table tr td,th{border:1px solid #000;}
</style>
样式:为th,td单元格添加粗细为一个像素的黑色边框。
3-7 <table>标签(为表格添加标题和摘要)
作用:表格还是需要添加一些标签进行优化,可以添加标题和摘要。
摘要
作用:增加表格的可读性(语义化),使搜索引擎更好的读懂表格内容,还可以使屏幕阅读器更好的帮助特殊用户读取表格内容。
样式:摘要的内容是不会在浏览器中显示出来的
<table summary="表格简介文本">
标题
作用:用以描述表格内容
样式:标题的显示位置:表格上方
<table>
<caption>标题文本</caption>
<tr>
<td>…</td>
<td>…</td>
…
</tr>
…
</table>
第四章 认识标签3
4-1 <a>标签(链接到另一个页面)
作用:使用<a>标签可实现超链接,它在网页制作中可以说是无处不在,只要有链接的地方,就会有这个标签
<a href="目标网址" title="鼠标滑过显示的文本">链接显示的文本</a>
样式:只要为文本加入a标签后,文字的颜色就会自动变为蓝色(被点击过的文本颜色为紫色)
title
作用:这个属性在实际网页开发中作用很大,主要方便搜索引擎了解链接地址的内容(语义化更友好)
4-2 在新建浏览器窗口中打开链接
target="_blank"
<a href="目标网址" target="_blank">click here!</a>
4-3 <mailto>标签(链接Email地址)
作用:能让访问者便捷向网站管理者发送电子邮件。
注意:如果mailto后面同时有多个参数的话,第一个参数必须以“?”开头,后面的参数每一个都以“&”分隔。
4-4 <img>标签(为网页插入图片)
<img src="图片地址" alt="下载失败时的替换文本" title = "提示文本">
src:标识图像的位置;
alt:指定图像的描述性文本,当图像不可见时(下载不成功时),可看到该属性指定的文本;
title:提供在图像可见时对图像的描述(鼠标滑过图片时显示的文本);
注意:图像可以是GIF,PNG,JPEG格式的图像文件。
第五章 与浏览者交互,表单标签
5-1 使用表单标签,与用户交互
定义:表单是可以把浏览者输入的数据传送到服务器端,这样服务器端程序就可以处理表单传过来的数据。
<form method="传送方式" action="服务器文件">
form :<form>标签是成对出现的,以<form>开始,以</form>结束。
action :浏览者输入的数据被传送到的地方,比如一个PHP页面(save.php)。
method : 数据传送的方式(get/post)。
注意:
1、所有表单控件(文本框、文本域、按钮、单选框、复选框等)都必须放在 <form></form> 标签之间(否则用户输入的信息可提交不到服务器上哦!)。
2、method : post/get 的区别这一部分内容属于后端程序员考虑的问题。
5-2 文本输入框、密码输入框
作用 :当用户要在表单中键入字母、数字等内容时,就会用到文本输入框。文本框也可以转化为密码输入框。
<form>
<input type="text/password" name="名称" value="文本" />
</form>
type :
当type="text"时,输入框为文本输入框;
当type="password"时, 输入框为密码输入框。
name:为文本框命名,以备后台程序ASP 、PHP使用。
value:为文本输入框设置默认值。(一般起到提示作用)
5-3 文本域(多行文本输入)
<textarea rows="行数" cols="列数">文本</textarea>
cols :多行输入域的列数。
rows :多行输入域的行数。
注意 :
1、 <textarea>标签是成对出现的,以<textarea>开始,以</textarea>结束。
2.、在<textarea></textarea>标签之间可以输入默认值
5-4 单选框、复选框(让用户选择)
作用 : 在使用表单设计调查表时,为了减少用户的操作,使用选择框是一个好主意
html中有两种选择框,即单选框和复选框
两者的区别是单选框中的选项用户只能选择一项,而复选框中用户可以任意选择多项,甚至全选
<input type="radio/checkbox" value="值" name="名称" checked="checked"/>
type:
当 type="radio" 时,控件为单选框
当 type="checkbox" 时,控件为复选框
value:提交数据到服务器的值(后台程序PHP使用)
name:为控件命名,以备后台程序 ASP、PHP 使用
checked:当设置 checked="checked" 时,该选项被默认选中
注意:同一组的单选按钮,name 取值一定要一致
5-5 下拉列表框(节省空间)
优点:
- 可以有效的节省网页空间
- 既可以单选、又可以多选
<select>
<option value="看书">看书</option>
<option value="旅游">旅游</option>
<option value="运动">运动</option>
<option value="购物">购物</option>
</select>
value:提交的值,文本内容是显示的值
selected="selected":设置selected="selected"属性,则该选项就被默认选中。
5-6下拉列表框进行多选
multiple="multiple":在 windows 操作系统下,进行多选时按下Ctrl键同时进行单击(在 Mac下使用 Command +单击),可以选择多个选项。
5-7 提交按钮
定义:当用户需要提交表单信息到服务器时,需要用到提交按钮。
<input type="submit" value="提交">
type:只有当type值设置为submit时,按钮才有提交作用
value:按钮上显示的文字
5-8 重置按钮
定义:当用户需要重置表单信息到初始时的状态时,比如用户输入“用户名”后,发现书写有误,可以使用重置按钮使输入框恢复到初始状态
<input type="reset" value="重置">
type:只有当type值设置为reset时,按钮才有重置作用
value:按钮上显示的文字
5-9 form表单中的label标签
定义:如果你在 label 标签内点击文本,就会触发此控件。
就是说,当用户单击选中该label标签时,浏览器就会自动将焦点转到和标签相关的表单控件上(就自动选中和该label标签相关连的表单控件上)。
作用:为鼠标用户改进了可用性。
<label for="控件id名称">
注意:标签的 for 属性中的值应当与相关控件的 id 属性值一定要相同。
<label for="male">男</label>
<input type="radio" name="gender" id="male" />
第六章 开始学习CSS,为网页添加样式
6-1 认识css样式
定义:CSS全称为“层叠样式表 (Cascading Style Sheets)”
作用:定义HTML内容在浏览器内的显示样式,如文字大小、颜色、字体加粗等。
优点:通过定义某个样式,可以让不同网页位置的文字有着统一的字体、字号或者颜色等。
p{
font-size:12px;
color:red;
font-weight:bold;
}
6-3 css代码语法
css 样式由选择符和声明组成,而声明又由属性和值组成
选择符:又称选择器,指明网页中要应用样式规则的元素,如本例中是网页中所有的段(p)的文字将变成蓝色,而其他的元素(如ol)不会受到影响。
声明:在英文大括号“{}”中的的就是声明,属性和值之间用英文冒号“:”分隔。当有多条声明时,中间可以英文分号“;”分隔,
注意:
1、最后一条声明可以没有分号,但是为了以后修改方便,一般也加上分号。
2、为了使用样式更加容易阅读,可以将每条代码写在一个新行内
6-4 css注释代码
/*注释语句*/
第七章 CSS样式基本知识
7-1 内联式css样式(直接写在现有的HTML标签中)
CSS 样式代码插入的形式:内联式、嵌入式和外部式
内联式:
<p style="color:red">这里文字是红色。</p>
注意:css样式代码要写在style=""双引号中,如果有多条css样式代码设置可以写在一起,中间用分号隔开。
7-2 嵌入式css样式(写在当前的文件中)
定义:嵌入式css样式,就是可以把css样式代码写在<style type="text/css"></style>标签之间
注意:嵌入式css样式必须写在<style></style>之间,并且一般情况下嵌入式css样式写在<head></head>之间。
<style type="text/css">
span{
color:red;
}
</style>
7-3 外部式css样式(写在单独的一个文件中)
定义:外部式css样式(也可称为外联式)就是把css代码写一个单独的外部文件中,这个css样式文件以“.css”为扩展名,在<head>内(不是在<style>标签内)使用<link>标签将css样式文件链接到HTML文件内
<link href="base.css" rel="stylesheet" type="text/css" />
注意:
1、css样式文件名称以有意义的英文字母命名,如 main.css。
2、rel="stylesheet" type="text/css" 是固定写法不可修改。
3、<link>标签位置一般写在<head>标签之内。
7-4 三种方法的优先级
内联式 > 嵌入式 > 外部式
就近原则(离被设置元素越近优先级别越高)
注意:嵌入式>外部式有一个前提:嵌入式css样式的位置一定在外部式的后面。
第八章 CSS选择器
8-1 选择器
每一条css样式声明(定义)由两部分组成
选择器{
样式;
}
定义:在{}之前的部分就是“选择器”,“选择器”指明了{}中的“样式”的作用对象,也就是“样式”作用于网页中的哪些元素
8-2 标签选择器
定义:标签选择器其实就是html代码中的标签。如<html>、<body>、<h1>、<p>、<img>。
p{font-size:12px;line-height:1.6em;}
为p标签设置12px字号,行间距设置1.6em的样式。
8-3 类选择器
.类选器名称{css样式代码;}
注意:
1、英文圆点开头
2、其中类选器名称可以任意起名(但不要起中文噢)
使用方法:
第一步:使用合适的标签把要修饰的内容标记起来,如下:
<span>胆小如鼠</span>
第二步:使用class="类选择器名称"为标签设置一个类,如下:
<span class="stress">胆小如鼠</span>
第三步:设置类选器css样式,如下:
.stress{color:red;}/*类前面要加入一个英文圆点*/
8-4 ID选择器
注意:
1、为标签设置id="ID名称",而不是class="类名称"。
2、ID选择符的前面是井号(#)号,而不是英文圆点(.)。
#setGreen{
color:green;
}
<span id="setGreen">公开课</span>
8-5 类和ID选择器的区别
相同点:可以应用于任何元素
不同点:
1、ID选择器只能在文档中使用一次。
2、可以使用类选择器词列表方法为一个元素同时设置多个样式。
.stress{
color:red;
}
.bigsize{
font-size:25px;
}
<p>到了<span class="stress bigsize">三年级</span>下学期时,我们班上了一节公开课...</p>
8-6 子选择器
定义:子选择器,即大于符号(>),用于选择指定标签元素的第一代子元素。
.food>li{border:1px solid red;}
这行代码会使class名为food下的子元素li加入红色实线边框。
8-7 包含(后代)选择器
定义:包含选择器,即加入空格,用于选择指定标签元素下的后辈元素。
注意:>作用于元素的第一代后代,空格作用于元素的所有后代。
.first span{color:red;}
8-8 通用选择器
定义:通用选择器使用一个(*)号指定,它的作用是匹配html中所有标签元素
* {color:red;}
8-9 伪类选择符
定义:它允许给html不存在的标签(标签的某种状态)设置样式
a:hover{color:red;}
a 标签鼠标滑过的状态设置字体颜色变红
8-10 分组选择符
定义:当你想为html中多个标签元素设置同一个样式时,可以使用分组选择符(,)
h1,span{color:red;}
它相当于下面两行代码:
h1{color:red;}
span{color:red;}
第9章 CSS的继承、层叠和特殊性
9-1 继承
定义:继承是一种规则,它允许样式不仅应用于某个特定html标签元素,而且应用于其后代。
9-2 特殊性
定义:浏览器是根据权值来判断使用哪种css样式的,权值高的就使用哪种css样式。
标签的权值为1,类选择符的权值为10,ID选择符的权值最高为100。例如下面的代码:
p{color:red;} /*权值为1*/
p span{color:green;} /*权值为1+1=2*/
.warning{color:white;} /*权值为10*/
p span.warning{color:purple;} /*权值为1+1+10=12*/
#footer .note p{color:yellow;} /*权值为100+10+1=111*/
注意:还有一个权值比较特殊--继承也有权值但很低,有的文献提出它只有0.1,所以可以理解为继承的权值最低。
9-3 层叠
定义:层叠就是在html文件中对于同一个元素可以有多个css样式存在,当有相同权重的样式存在时,会根据这些css样式的前后顺序来决定,处于最后面的css样式会被应用。
内联样式表(标签内部)> 嵌入样式表(当前文件中)> 外部样式表(外部文件中)。
9-4 重要性
!important
p{color:red!important;}
p{color:green;}
<p class="first">三年级时,我还是一个<span>胆小如鼠</span>的小女孩。</p>
浏览器默认的样式 < 网页制作者样式 < 用户自己设置的样式
注意:!important要写在分号的前面
第十章 CSS格式化排版
10-1 文字排版--字体
注意:一般设置的字体都要是用户本地安装的字体,不然会显示为浏览器默认字体。
现在网页一般都喜欢设置“微软雅黑”
body{font-family:"Microsoft Yahei";}
或者
body{font-family:"微软雅黑";}
第一种方法比第二种方法兼容性更好一些。
这种字体即美观又可以在客户端安全的显示出来(用户本地一般都是默认安装的)。
10-2 文字排版--字号、颜色
body{font-size:12px;color:#666}
设置网页中文字的字号为12像素,并把字体颜色设置为#666(灰色)
10-3 文字排版--粗体
p span{font-weight:bold;
可以用来替代和h1-h6或strong的粗体样式
10-4 文字排版--斜体
p a{font-style:italic;}
10-5 文字排版--下划线
p a{text-decoration:underline;}
10-6 文字排版--删除线
.oldPrice{text-decoration:line-through;}
10-7 段落排版--缩进
p{text-indent:2em;}
2em的意思就是文字的2倍大小。
10-8 段落排版--行间距(行高)
p{line-height:1.5em;}
段落行间距为1.5倍。
10-9 段落排版--中文字间距、字母间距
h1{
letter-spacing:50px;
}
...
<h1>了不起的盖茨比</h1>
10-10 段落排版--对齐
块状元素中的文本、图片设置居中样式
h1{
text-align:center;
}
<h1>了不起的盖茨比</h1>
————————————————————
h1{
text-align:left;
}
h1{
text-align:right;
}
第11章 CSS盒模型
11-1 元素分类
定义:在CSS中,html中的标签元素大体被分为三种不同的类型:块状元素、内联元素(又叫行内元素)和内联块状元素。
常用的块状元素有:
<div>、<p>、<h1>...<h6>、<ol>、<ul>、<dl>、<table>、<address>、<blockquote> 、<form>
常用的内联元素有:
<a>、<span>、
、<i>、<em>、<strong>、<label>、<q>、<var>、<cite>、<code>
常用的内联块状元素有:
<img>、<input>
11-2 元素分类--块级元素
<div>、 <p>、<h1>、<form>、<ul> 、 <li>
特点:
1、每个块级元素都从新的一行开始,并且其后的元素也另起一行。
2、元素的高度、宽度、行高以及顶和底边距都可设置。
3、元素宽度在不设置的情况下,是它本身父容器的100%(和父元素的宽度一致),除非设定一个宽度。
a{display:block;}
将内联元素a转换为块状元素,从而使a元素具有块状元素特点。
11-3 元素分类--内联元素
<span>、<a>、<label>、 <strong> 和<em>
特点:
1、和其他元素都在一行上;
2、元素的高度、宽度及顶部和底部边距不可设置;
3、元素的宽度就是它包含的文字或图片的宽度,不可改变。
div{
display:inline;
}
<div>我要变成内联元素</div>
块状元素div转换为内联元素,从而使 div 元素具有内联元素特点
11-4 元素分类--内联块状元素
<img>、<input>
定义:同时具备内联元素、块状元素的特点
特点:
1、和其他元素都在一行上;
2、元素的高度、宽度、行高以及顶和底边距都可设置。
display:inline-block
将元素设置为内联块状元素
11-5 什么是盒模型
<div>、<ul>、<ol>、<p>、<h>、<table>
盒模型=
页面元素:div
+内容:文字、图片、标签元素
页面元素与内容的距离=盒子模型内填充(padding)
页面元素与页面元素的距离=盒子模型外边距(margin)
页面元素的边框(border)
内填充、外边距、边框都有四个方向:padding-top、padding-right、padding-bottom、padding-left
高度/宽度=内填充+外边距+边框
11-6 盒模型--边框(一)
定义:盒子模型的边框就是围绕着内容及补白的线,这条线你可以设置它的粗细、样式和颜色(边框三个属性)。
div{
border:2px solid red;
}
上面是 border 代码的缩写形式,可以分开写:
div{
border-width:2px;
border-style:solid;
border-color:red;
}
注意:
1、border-style(边框样式)常见样式有:
dashed(虚线)| dotted(点线)| solid(实线)。
2、border-color(边框颜色)中的颜色可设置为十六进制颜色,如:
border-color:#888;//前面的井号不要忘掉。
3、border-width(边框宽度)中的宽度也可以设置为:
thin | medium | thick(但不是很常用),最常还是用像素(px)。
11-7 盒模型--边框(二)
div{border-bottom:1px solid red;}
为 p 标签单独设置下边框,而其它三边都不设置边框样式
11-8 盒模型--宽度和高度
定义:填充以里的内容范围
元素实际宽度(盒子的宽度)=左边界+左边框+左填充+内容宽度+右填充+右边框+右边界
高度同理
11-9 盒模型--填充
定义:元素内容与边框之间是可以设置距离的,称之为“填充”。填充也可分为上、右、下、左(顺时针)。
div{padding:20px 10px 15px 30px;}
顺序一定不要搞混。可以分开写上面代码:
div{
padding-top:20px;
padding-right:10px;
padding-bottom:15px;
padding-left:30px;
}
如果上、右、下、左的填充都为10px;可以这么写
div{padding:10px;}
如果上下填充一样为10px,左右一样为20px,可以这么写:
div{padding:10px 20px;}
11-10 盒模型--边界
定义:元素与其它元素之间的距离
div{margin:20px 10px 15px 30px;}
也可以分开写:
div{
margin-top:20px;
margin-right:10px;
margin-bottom:15px;
margin-left:30px;
}
如果上右下左的边界都为10px;可以这么写:
div{margin:10px;}
如果上下边界一样为10px,左右一样为20px,可以这么写:
div{ margin:10px 20px;}
注意:padding和margin的区别,padding在边框里,margin在边框外。
第十二章 CSS布局模型
12-1 css布局模型
在网页中,元素有三种布局模型:
1、流动模型(Flow)
2、浮动模型 (Float)
3、层模型(Layer)
12-2 流动模型(一)
定义:流动(Flow)是默认的网页布局模式。也就是说网页在默认状态下的 HTML 网页元素都是根据流动模型来分布网页内容的。
特点:
1、在默认状态下,块状元素的宽度都为100%
2、在流动模型下,内联元素都会在所处的包含元素内从左到右水平分布显示。
12-4 浮动模型
定义:任何元素在默认情况下是不能浮动的,但可以用 CSS 定义为浮动,
两个 div 元素一行显示
div{
width:200px;
height:200px;
border:2px red solid;
float:left;
}
<div id="div1"></div>
<div id="div2"></div>
两个元素右浮动
div{
width:200px;
height:200px;
border:2px red solid;
float:right;
}
两个元素一左一右可以实现一行显示
div{
width:200px;
height:200px;
border:2px red solid;
}
#div1{float:left;}
#div2{float:right;}
12-5 什么是层模型?
定义:层布局模型就像是图像软件PhotoShop中非常流行的图层编辑功能一样,每个图层能够精确定位操作,但在网页设计领域,由于网页大小的活动性,层布局没能受到热捧。但是在网页上局部使用层布局还是有其方便之处的。
层模型有三种形式:
1、绝对定位(position: absolute)
2、相对定位(position: relative)
3、固定定位(position: fixed)
12-6 层模型--绝对定位
定义:如果想为元素设置层模型中的绝对定位,需要设置position:absolute(表示绝对定位),这条语句的作用将元素从文档流中拖出来,然后使用left、right、top、bottom属性相对于其最接近的一个具有定位属性的父包含块进行绝对定位。如果不存在这样的包含块,则相对于body元素,即相对于浏览器窗口。
相对于浏览器的移动
12-7 层模型--相对定位
定义:元素设置层模型中的相对定位,需要设置position:relative(表示相对定位),它通过left、right、top、bottom属性确定元素在正常文档流中的偏移位置。相对定位完成的过程是首先按static(float)方式生成一个元素(并且元素像层一样浮动了起来),然后相对于以前的位置移动,移动的方向和幅度由left、right、top、bottom属性确定,偏移前的位置保留不动。
相对于以前位置的移动
#div1{
width:200px;
height:200px;
border:2px red solid;
position:relative;
left:100px;
top:50px;
}
<div id="div1"></div>
相对于以前位置向下移动50px,向右移动100px
12-8 层模型--固定定位
定义:fixed:表示固定定位,与absolute定位类型类似,但它的相对移动的坐标是视图(屏幕内的网页窗口)本身。由于视图本身是固定的,它不会随浏览器窗口的滚动条滚动而变化,除非你在屏幕中移动浏览器窗口的屏幕位置,或改变浏览器窗口的显示大小,因此固定定位的元素会始终位于浏览器窗口内视图的某个位置,不会受文档流动影响,这与background-attachment:fixed;属性功能相同。
#div1{
width:200px;
height:200px;
border:2px red solid;
position:fixed;
left:100px;
top:50px;
}
<p>文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本。</p>
浏览器视图向右移动100px,向下移动50px
12-9 Relative与Absolute组合使用
1、参照定位的元素必须是相对定位元素的前辈元素:
2、参照定位的元素必须加入position:relative;
3、定位元素加入position:absolute,便可以使用top、bottom、left、right来进行偏移定位了。
第十三章 CSS代码缩写,占用更少的带宽
13-1 盒模型代码简写
margin:10px 15px 12px 14px;/*上设置为10px、右设置为15px、下设置为12px、左设置为14px*/
通常有下面三种缩写方法:
1、如果top、right、bottom、left的值相同,如下面代码:
margin:10px 10px 10px 10px;
可缩写为:
margin:10px;
2、如果top和bottom值相同、left和 right的值相同,如下面代码:
margin:10px 20px 10px 20px;
可缩写为:
margin:10px 20px;
3、如果left和right的值相同,如下面代码:
margin:10px 20px 30px 20px;
可缩写为:
margin:10px 20px 30px;
注意:padding、border的缩写方法和margin是一致的。
13-2 颜色值缩写
定义:当你设置的颜色是16进制的色彩值时,如果每两位的值相同,可以缩写一半。
p{color:#000000;}
可以缩写为:
p{color: #000;}
p{color: #336699;}
可以缩写为:
p{color: #369;}
13-3 字体缩写
body{
font-style:italic;
font-variant:small-caps;
font-weight:bold;
font-size:12px;
line-height:1.5em;
font-family:"宋体",sans-serif;
}
这么多行的代码其实可以缩写为一句:
body{
font:italic small-caps bold 12px/1.5em "宋体",sans-serif;
}
注意:
1、使用这一简写方式你至少要指定 font-size 和 font-family 属性,其他的属性(如 font-weight、font-style、font-variant、line-height)如未指定将自动使用默认值。
2、在缩写时 font-size 与 line-height 中间要加入“/”斜扛。
一般情况下因为对于中文网站,英文还是比较少的,所以下面缩写代码比较常用:
body{
font:12px/1.5em "宋体",sans-serif;
}
第十四章 单位和值
14-1 颜色值
1、英文命令颜色
p{color:red;}
2、RGB颜色
这个与 photoshop 中的 RGB 颜色是一致的,由 R(red)、G(green)、B(blue) 三种颜色的比例来配色。
p{color:rgb(133,45,200);}
每一项的值可以是 0~255 之间的整数,也可以是 0%~100% 的百分数。如:
p{color:rgb(20%,33%,25%);}
3、十六进制颜色
这种颜色设置方法是现在比较普遍使用的方法,其原理其实也是 RGB 设置,但是其每一项的值由 0-255 变成了十六进制 00-ff。
p{color:#00ffff;}
14-2 长度值
比较常用到px(像素)、em、% 百分比
1、像素
像素为什么是相对单位呢?因为像素指的是显示器上的小点(CSS规范中假设“90像素=1英寸”)。实际情况是浏览器会使用显示器的实际像素值有关,在目前大多数的设计者都倾向于使用像素(px)作为单位。
2、em
就是本元素给定字体的 font-size 值,如果元素的 font-size 为 14px ,那么 1em = 14px;如果 font-size 为 18px,那么 1em = 18px。如下代码:
p{font-size:12px;text-indent:2em;}
上面代码就是可以实现段落首行缩进 24px(也就是两个字体大小的距离)。
3、百分比
p{font-size:12px;line-height:130%}
设置行高(行间距)为字体的130%(12 * 1.3 = 15.6px)。
第十五章 css样式设置小技巧
15-1 水平居中设置-行内元素
<style>
.txtCenter{
text-align:center;
}
</style>
<body>
<div class="txtCenter">我想要在父容器中水平居中显示。</div>
</body>
15-2 水平居中设置-定宽块状元素
当被设置元素为块状元素时用 text-align:center 就不起作用了,这时也分两种情况:定宽块状元素和不定宽块状元素
定义:块状元素的宽度width为固定值。
满足定宽和块状两个条件的元素是可以通过设置“左右margin”值为“auto”来实现居中的
<style>
div{
border:1px solid red;/*为了显示居中效果明显为 div 设置了边框*/
width:200px;/*定宽*/
margin:20px auto;/* margin-left 与 margin-right 设置为 auto */
}
</style>
也可以写成:
margin-left:auto;
margin-right:auto;
15-3 水平居中总结-不定宽块状元素方法(一)
实际工作中“不定宽度的块状元素”设置居中,比如网页上的分页导航,因为分页的数量是不确定的,所以我们不能通过设置宽度来限制它的弹性。
不定宽度的块状元素有三种方法居中(这三种方法目前使用的都很多):
1、加入 [table] 标签
2、设置 [display: inline]方法:与第一种类似,显示类型设为 行内元素,进行不定宽元素的属性设置
3、设置 [position:relative]和 left:50%:利用 相对定位 的方式,将元素向左偏移 50% ,即达到居中的目的
第一种方法:
利用table标签的长度自适应性---即不定义其长度也不默认父元素body的长度(table其长度根据其内文本长度决定),因此可以看做一个定宽度块元素,然后再利用定宽度块状居中的margin的方法,使其水平居中。
1、为需要设置的居中的元素外面加入一个 table 标签 ( 包括 <tbody>、<tr>、<td> )。
2、为这个 table 设置“左右 margin 居中”(这个和定宽块状元素的方法一样)。
<style>
table{
border:1px solid;
margin:0 auto;
}
</style>
15-4 水平居中总结-不定宽块状元素方法(二)
第二种方法:改变块级元素的 display 为 inline 类型(设置为 [行内元素 显示,然后使用 text-align:center
来实现居中效果。
html代码:
<body>
<div class="container">
<ul>
<li><a href="#">1</a></li>
<li><a href="#">2</a></li>
<li><a href="#">3</a></li>
</ul>
</div>
</body>
css代码:
<style>
.container{
text-align:center;
}
/* margin:0;padding:0(消除文本与div边框之间的间隙)*/
.container ul{
list-style:none;
margin:0;
padding:0;
display:inline;
}
/* margin-right:8px(设置li文本之间的间隔)*/
.container li{
margin-right:8px;
display:inline;
}
</style>
这种方法相比第一种方法的优势是不用增加无语义标签,但也存在着一些问题:它将块状元素的 display 类型改为 inline,变成了行内元素,所以少了一些功能,比如设定长度值。
15-5 水平居中总结-不定宽块状元素方法(三)
方法三:通过给父元素设置float,然后给父元素设置 position:relative和 left:50%,子元素设置 position:relative 和 left: -50% 来实现水平居中。
我们可以这样理解:假想ul层的父层(即下面例子中的div层)中间有条平分线将ul层的父层(div层)平均分为两份,ul层的css代码是将ul层的最左端与ul层的父层(div层)的平分线对齐;而li层的css代码则是将li层的平分线与ul层的最左端(也是div层的平分线)对齐,从而实现li层的居中。
代码如下:
<body>
<div class="container">
<ul>
<li><a href="#">1</a></li>
<li><a href="#">2</a></li>
<li><a href="#">3</a></li>
</ul>
</div>
</body>
css代码:
<style>
.container{
float:left;
position:relative;
left:50%
}
.container ul{
list-style:none;
margin:0;
padding:0;
position:relative;
left:-50%;
}
.container li{float:left;display:inline;margin-right:8px;}
</style>
15-6 垂直居中-父元素高度确定的单行文本
两种情况:父元素高度确定的单行文本,以及父元素高度确定的多行文本。
父元素高度确定的单行文本的竖直居中的方法是通过设置父元素的 height 和line-height高度一致来实现的。(height: 该元素的高度,line-height: 顾名思义,行高(行间距),指在文本中,行与行之间的 基线间的距离 )。
line-height 与 font-size 的计算值之差,在 CSS 中成为“行间距”。分为两半,分别加到一个文本行内容的顶部和底部。
这种文字行高与块高一致带来了一个弊端:当文字内容的长度大于块的宽时,就有内容脱离了块。
<div class="container">
hi,imooc!
</div>
css代码:
<style>
.container{
height:100px;
line-height:100px;
background:#999;
}
</style>
15-7 垂直居中-父元素高度确定的多行文本(方法一)
方法一:使用插入table(包括tbody、tr、td)标签,同时设置 vertical-align:middle。
css 中有一个用于竖直居中的属性 vertical-align,在父元素设置此样式时,会对inline-block类型的子元素都有用。
html代码:
<body>
<table><tbody><tr><td class="wrap">
<div>
<p>看我是否可以居中。</p>
</div>
</td></tr></tbody></table>
</body>
css代码:
table td{height:500px;background:#ccc}
因为 td 标签默认情况下就默认设置了 vertical-align 为 middle,所以我们不需要显式地设置了。
15-8 垂直居中-父元素高度确定的多行文本(方法二)
在 chrome、firefox 及 IE8 以上的浏览器下可以设置块级元素的 display 为 table-cell(设置为表格单元显示),激活 vertical-align 属性,但注意 IE6、7 并不支持这个样式, 兼容性比较差。
html代码:
<div class="container">
<div>
<p>看我是否可以居中。</p>
<p>看我是否可以居中。</p>
<p>看我是否可以居中。</p>
</div>
</div>
css代码:
<style>
.container{
height:300px;
background:#ccc;
display:table-cell;/*IE8以上及Chrome、Firefox*/
vertical-align:middle;/*IE8以上及Chrome、Firefox*/
}
</style>
这种方法的好处是不用添加多余的无意义的标签,但缺点也很明显,它的兼容性不是很好,不兼容 IE6、7而且这样修改display的block变成了table-cell,破坏了原有的块状元素的性质。
15-9 隐性改变display类型
当为元素(不论之前是什么类型元素,display:none 除外)设置以下 2 个句之一:
1、position : absolute
2、float : left 或 [float:right]
只要html代码中出现以上两句之一,元素的display显示类型就会自动变为以 display:inline-block(块状元素)的方式显示,当然就可以设置元素的 width 和 height 了,且默认宽度不占满父元素。
a 标签是 行内元素 ,所以设置它的 width 是 没有效果的,但是设置为 position:absolute 以后,就可以了。
<div class="container">
<a href="#" title="">进入课程请单击这里</a>
</div>
css代码
<style>
.container a{
position:absolute;
width:200px;
background:#ccc;
}
</style>