HTML+CSS摘要

本课来自http://www.imooc.com/learn/9
请不要用作商业用途。

HTML5

HTML介绍

HTML代码由标签组成,标签的语法是< XXX>.......</XXX>。

标签可以嵌套,而且一般为小写。

HTML有固定的格式:

<html> <head>...</head> <body>...</body> </html>

  • <html></html>称为根标签,所有的网页标签都在<html></html>中。
  • <head> 标签用于定义文档的头部,它是所有头部元素的容器。
  • 在<body>和</body>标签之间的内容是网页的主要内容,这里标签中的内容会在浏览器页面上显示出来。

<head>标签

下面这些标签可用在 head 部分:
<head> <title>...</title> <meta> <link> <style>...</style> <script>...</script> </head>

  • <title>标签:在<title>和</title>标签之间的文字内容是网页的标题信息,它会出现在浏览器的标题栏中。网页的title标签用于告诉用户和搜索引擎这个网页的主要内容是什么,搜索引擎可以通过网页标题,迅速的判断出网页的主题。
  • <meta>标签:(待补充)

HTML的注释

``

认识标签(第一部分)

添加段落——<p>

<p>段落文本</p> 注意一段文字要一个<p>标签

制作标题——<hx>

<hx>标题文本</hx> h1到h6字体逐渐变小

强调——<strong> <em>

<em>需要强调的文本</em> <em>默认用斜体表示
<strong>需要强调的文本</strong> <strong>默认用粗体表示

为文字设置单独的样式——<span>

<span>文本</span> <span>标签是没有语义的,它的作用就是为了设置单独的样式用的。

短文本引用——<q>

<q>引用文本</q>引用的文本不用加双引号,浏览器会对q标签自动添加双引号。

长文本引用——<blockquote>

<blockquote>引用文本</blockquote> 浏览器解析是缩进样式

换行——<br>

<br />是规范的写法,这是一个空标签,只有开始标签,没有结束标签

空格——&nbsp;

表示空格

添加水平线——<hr>

<hr/>是规范写法,这是一个空标签,只有开始标签,没有结束标签

为网页加入地址——<address>

<address>联系地址信息</address> 浏览器默认格式为斜体

加入代码——<code>

<code>代码语言</code>

加入大段代码——<pre>

<pre>语言代码段</pre> 在标签中文本可以保留空格和换行

认识标签(第二部分)

添加信息列表——<ul-li>

<ul> <li>信息<li> <ul>
ul-li是没有前后顺序的信息列表,ul-li在网页中显示的默认样式一般为:每项li前都自带一个圆点

添加有前后顺序的信息列表——<ol-li>

<ol> <li>信息<li> <ol>
网页中显示的默认样式一般为:每项<li>前都自带一个序号,序号默认从1开始

独立逻辑快划分——<div>

<div>…</div>
为div命名(命名必须唯一)的方法:
<div id="版块名称">…</div>

添加表格——<table>

创建表格的四个元素:table、tbody、tr、th、td

  • table
    <table>…</table>整个表格以<table>标记开始、</table>标记结束,table表格在没有添加css样式之前,在浏览器中显示是没有表格线的
  • tbody
    <tbody>…</tbody>当表格内容非常多时,表格会下载一点显示一点,但如果加上<tbody>标签后,这个表格就要等表格内容全部下载完才会显示
  • tr
    <tr>…</tr>表格的一行,所以有几对tr 表格就有几行
  • td
    <td>…</td>表格的一个单元格,一行中包含几对td,说明一行中就有几列
  • th
    <th>…</th>表格的头部的一个单元格,表格表头,th标签中的文本默认为粗体并且居中显示
  • 用CSS为表格加上边框(待补充)
为表格添加摘要

<table summary="表格简介文本">

为表格添加标题——<caption>

<table> <caption>标题文本</caption> <tr> <td>…</td> <td>…</td> </tr> </table>

认识标签(第三部分)

链接到另一个页面——<a>

<a href="目标网址" title="鼠标滑过显示的文本">链接显示的文本</a>
若要在新的浏览器窗口打开页面:
<a href="目标网址" target="_blank">click here!</a>

在网页中链接Email地址——mailto

如果mailto后面同时有多个参数的话,第一个参数必须以“?”开头,后面的参数每一个都以“&”分隔。



example:

为网页插入图片——<img>

![](图片地址)

  • src:
    标识图像的位置
  • alt:
    指定图像的描述性文本,当图像不可见时(下载不成功时),可看到该属性指定的文本
  • title:
    提供在图像可见时对图像的描述(鼠标滑过图片时显示的文本)
  • 图像可以是GIF,PNG,JPEG格式的图像文本

表单标签

与用户交互——表单标签

<form method="传送方式" action="服务器文件">

  • <form> :
    <form>标签是成对出现的,以<form>开始,以</form>结束
  • action :
    浏览者输入的数据被传送到的地方,比如一个PHP页面(save.php)
  • method :
    数据传送的方式(get/post)
  • 所有表单控件(文本框、文本域、按钮、单选框、复选框等)都必须放在 <form></form> 标签之间(否则用户输入的信息可提交不到服务器上哦!)

文本输入框,密码输入框

<form> <input type="text/password" name="名称" value="文本" /> </form>

  • type:
    当type="text"时,输入框为文本输入框
    当type="password"时, 输入框为密码输入框
  • name:
    为文本框命名,以备后台程序ASP 、PHP使用
  • value:
    为文本输入框设置默认值。(一般起到提示作用)

多行文本输入

<textarea rows="行数" cols="列数">文本</textarea>

  • <textarea>
    <textarea>标签是成对出现的,以<textarea>开始,以</textarea>结束。

  • cols :多行输入域的列数

  • rows :多行输入域的行数

使用单选框和复选框

<input type="radio/checkbox" value="值" name="名称" checked="checked"/>

  • type:
    当 type="radio" 时,控件为单选框
    当 type="checkbox" 时,控件为复选框
  • value:提交数据到服务器的值(后台程序PHP使用)
  • name:为控件命名,以备后台程序 ASP、PHP 使用
  • checked:当设置 checked="checked" 时,该选项被默认选中

下拉列表框

  • value:


  • selected="selected":
    设置selected="selected"属性,则该选项就被默认选中
  • 多选操作:
    设置multiple="multiple"属性,就可以实现多选功能


重置表单信息

<input type="reset" value="重置">

  • type:只有当type值设置为reset时,按钮才有重置作用
  • value:按钮上显示的文字


标签<label>

<label for="控件id名称">
label标签不会向用户呈现任何特殊效果,它的作用是为鼠标用户改进了可用性。如果你在 label 标签内点击文本,就会触发此控件。就是说,当用户单击选中该label标签时,浏览器就会自动将焦点转到和标签相关的表单控件上(就自动选中和该label标签相关连的表单控件上)标签的 for 属性中的值应当与相关控件的 id 属性值一定要相同

CSS

CSS样式

认识CSS样式

CSS全称为“层叠样式表 (Cascading Style Sheets)”,它主要是用于定义HTML内容在浏览器内的显示样式,如文字大小、颜色、字体加粗等
p{ font-size:12px; color:red; font-weight:bold; }

CSS代码语法

  • 选择符:又称选择器,指明网页中要应用样式规则的元素,如本例中是网页中所有的段(p)的文字将变成蓝色,而其他的元素(如ol)不会受到影响
  • 声明:在英文大括号“{}”中的的就是声明,属性和值之间用英文冒号“:”分隔。当有多条声明时,中间可以英文分号“;”分隔,如下所示:
    p{font-size:12px;color:red;}
  • 最后一条声明可以没有分号,但是为了以后修改方便,一般也加上分号
  • 为了使用样式更加容易阅读,可以将每条代码写在一个新行内

CSS代码注释

和C++一样

CSS样式基本

内联式css样式,直接写在现有的HTML标签中

<p style="color:red;font-size:12px">这里文字是红色。</p>

嵌入式css样式,写在当前的文件中

实现把三个<span>标签中的文字设置为红色:
<style type="text/css"> span{ color:red; } </style>

外部式css样式,写在单独的一个文件中

外部式css样式(也可称为外联式)就是把css代码写一个单独的外部文件中,这个css样式文件以“.css”为扩展名,在<head>内(不是在<style>标签内)使用<link>标签将css样式文件链接到HTML文件内,如下面代码:
<link href="base.css" rel="stylesheet" type="text/css" />

  • css样式文件名称以有意义的英文字母命名,如 main.css
  • rel="stylesheet" type="text/css" 是固定写法不可修改
  • <link>标签位置一般写在<head>标签之内。

三种方法的优先级

在相同权值的情况下,就是--就近原则(离被设置元素越近优先级别越高)

CSS选择器

什么是CSS选择器?

每一条css样式声明(定义)由两部分组成,形式如下:
选择器{ 样式; }
在{}之前的部分就是“选择器”,“选择器”指明了{}中的“样式”的作用对象,也就是“样式”作用于网页中的哪些元素

类选择器

.类选器名称{css样式代码;}

  • 英文圆点开头
  • 其中类选器名称可以任意起名(但不要起中文噢)
    使用方法:
  • 使用合适的标签把要修饰的内容标记起来,如下:
    <span>胆小如鼠</span>
  • 使用class="类选择器名称"为标签设置一个类,如下:
    <span class="stress">胆小如鼠</span>
  • 设置类选器css样式,如下:
    .stress{color:red;}/*类前面要加入一个英文圆点*/

ID选择器

  • 为标签设置id="ID名称",而不是class="类名称"
  • ID选择符的前面是井号(#)号,而不是英文圆点(.)
ID选择器和类选择器的异同
相同点:

可以应用于任何元素

不同点:
  • ID选择器只能在文档中使用一次。与类选择器不同,在一个HTML文档中,ID选择器只能使用一次,而且仅一次。而类选择器可以使用多次
  • 可以使用类选择器词列表方法为一个元素同时设置多个样式。我们可以为一个元素同时设多个样式,但只可以用类选择器的方法实现,ID选择器是不可以的(不能使用 ID 词列表)

子选择器

子选择器,即大于符号(>),用于选择指定标签元素的第一代子元素
.food>li{border:1px solid red;}
这行代码会使class名为food下的子元素li(水果、蔬菜)加入红色实线边框

包含(后代)选择器

包含选择器,即加入空格,用于选择指定标签元素下的后辈元素。如右侧代码编辑器中的代码:
.first span{color:red;}
这行代码会使第一段文字内容中的“胆小如鼠”字体颜色变为红色。
请注意这个选择器与子选择器的区别,子选择器(child selector)仅是指它的直接后代,或者你可以理解为作用于子元素的第一代后代。而后代选择器是作用于所有子后代元素。后代选择器通过空格来进行选择,而子选择器是通过“>”进行选择。
总结:>作用于元素的第一代后代,空格作用于元素的所有后代

通用选择器

通用选择器是功能最强大的选择器,它使用一个(*)号指定,它的作用是匹配html中所有标签元素,如下使用下面代码使用html中任意标签元素字体颜色全部设置为红色:
* {color:red;}

伪类选择符

更有趣的是伪类选择符,为什么叫做伪类选择符,它允许给html不存在的标签(标签的某种状态)设置样式,比如说我们给html中一个标签元素的鼠标滑过的状态来设置字体颜色:
a:hover{color:red;}
上面一行代码就是为 a 标签鼠标滑过的状态设置字体颜色变红。
现在比较常用的是 a:hover 的组合

分组选择符

当你想为html中多个标签元素设置同一个样式时,可以使用分组选择符(,),如下代码为右侧代码编辑器中的h1、span标签同时设置字体颜色为红色:
h1,span{color:red;}

CSS的继承、层叠和特殊性

继承

CSS的某些样式是具有继承性的,那么什么是继承呢?继承是一种规则,它允许样式不仅应用于某个特定html标签元素,而且应用于其后代。比如下面代码:
p{color:red;} <p>三年级时,我还是一个<span>胆小如鼠</span>的小女孩。</p>

特殊性

浏览器是根据权值来判断使用哪种css样式的,权值高的就使用哪种css样式。

  • 规则:
    标签的权值为1,类选择符的权值为10,ID选择符的权值最高为100
    继承也有权值但很低,有的文献提出它只有0.1,所以可以理解为继承的权值最低。

层叠

层叠就是在html文件中对于同一个元素可以有多个css样式存在,当有相同权重的样式存在时,会根据这些css样式的前后顺序来决定,处于最后面的css样式会被应用

  • 内联样式表(标签内部)> 嵌入样式表(当前文件中)> 外部样式表(外部文件中)

重要性

我们可以使用!important来为某些样式设置具有最高权值
p{color:red!important;} p{color:green;} <p class="first">三年级时,我还是一个<span>胆小如鼠</span>的小女孩。</p>
注意:!important要写在分号的前面
浏览器默认的样式 < 网页制作者样式 < 用户自己设置的样式,但记住!important优先级样式是个例外,权值高于用户自己设置的样式

CSS格式化排版

字体

body{font-family:"Microsoft Yahei";}

字号、颜色

body{font-size:12px;color:#666}

粗体

p span{font-weight:bold;}

斜体

p a{font-style:italic;}

下划线

p a{text-decoration:underline;}

删除线

.oldPrice{text-decoration:line-through;}

缩进

p{text-indent:2em;} <p>1922年的春天,一个想要成名名叫尼克卡拉威(托比?马奎尔Tobey Maguire 饰)的作家,离开了美国中西部,来到了纽约。那是一个道德感渐失,爵士乐流行,走私为王,股票飞涨的时代。为了追寻他的美国梦,他搬入纽约附近一海湾居住。</p>

2em的意思就是文字的2倍大小。

行间距(行高)

p{line-height:1.5em;}

中文字间距、字母间距

如果想在网页排版中设置文字间隔或者字母间隔就可以使用 letter-spacing 来实现,如下面代码:

h1{ letter-spacing:50px; } <h1>了不起的盖茨比</h1>
注意:这个样式使用在英文单词时,是设置字母与字母之间的间距。

单词间距设置:

h1{ word-spacing:50px; } <h1>welcome to imooc!</h1>

对齐

使用text-align样式代码,如下代码可实现文本居中显示
h1{ text-align:center; } <h1>了不起的盖茨比</h1>

CSS盒模型

元素分类

块状元素

<div>、<p>、<h1>...<h6>、<ol>、<ul>、<dl>、<table>、<address>、<blockquote> 、<form>

内联元素

<a>、<span>、<br>、<i>、<em>、<strong>、<label>、<q>、<var>、<cite>、<code>

内联块状元素

<img>、<input>

块级元素

设置display:block就是将元素显示为块级元素。如下代码就是将内联元素a转换为块状元素,从而使a元素具有块状元素特点。
a{display:block;}

  • 每个块级元素都从新的一行开始,并且其后的元素也另起一行。(真霸道,一个块级元素独占一行)
  • 元素的高度、宽度、行高以及顶和底边距都可设置
  • 元素宽度在不设置的情况下,是它本身父容器的100%(和父元素的宽度一致),除非设定一个宽度

内联元素

块状元素也可以通过代码display:inline将元素设置为内联元素,如下代码就是将块状元素div转换为内联元素,从而使 div 元素具有内联元素特点
div{ display:inline; }

  • 和其他元素都在一行上;
  • 元素的高度、宽度及顶部和底部边距不可设置;
  • 元素的宽度就是它包含的文字或图片的宽度,不可改变

内联块状元素

代码display:inline-block就是将元素设置为内联块状元素

  • 和其他元素都在一行上;
  • 元素的高度、宽度、行高以及顶和底边距都可设置

盒模型

边框(一)

盒子模型的边框就是围绕着内容及补白的线,这条线你可以设置它的粗细、样式和颜色(边框三个属性)
div{ border-width:2px; border-style:solid; border-color:red; }

  • border-style(边框样式)常见样式有:
    dashed(虚线)| dotted(点线)| solid(实线)
  • border-color(边框颜色)中的颜色可设置为十六进制颜色
    border-color:#888;//前面的井号不要忘掉
  • border-width(边框宽度)中的宽度也可以设置为:
    thin | medium | thick(但不是很常用),最常还是用象素(px)

边框(二)

css 样式中允许只为一个方向的边框设置样式:
div{border-bottom:1px solid red;}

宽度和高度

css内定义的宽(width)和高(height),指的是填充以里的内容范围
因此一个元素实际宽度(盒子的宽度)=左边界+左边框+左填充+内容宽度+右填充+右边框+右边界


div{ width:200px; padding:20px; border:1px solid red; margin:10px; }
元素的实际长度为:10px+1px+20px+200px+20px+1px+10px=262px

填充

元素内容与边框之间是可以设置距离的,称之为“填充”。填充也可分为上、右、下、左(顺时针)。如下代码:
div{ padding-top:20px; padding-right:10px; padding-bottom:15px; padding-left:30px; }

边界

元素与其它元素之间的距离可以使用边界(margin)来设置。边界也是可分为上、右、下、左。如下代码:
div{ margin-top:20px; margin-right:10px; margin-bottom:15px; margin-left:30px; }

总结一下:padding和margin的区别,padding在边框里,margin在边框外。

CSS布局模型

css布局模型

CSS包含3种基本的布局模型,用英文概括为:Flow、Layer 和 Float。
在网页中,元素有三种布局模型:

  • 流动模型(Flow)
  • 浮动模型 (Float)
  • 层模型(Layer)

流动模型

先来说一说流动模型,流动(Flow)是默认的网页布局模式。也就是说网页在默认状态下的 HTML 网页元素都是根据流动模型来分布网页内容的。

  • 块状元素都会在所处的包含元素内自上而下按顺序垂直延伸分布,因为在默认状态下,块状元素的宽度都为100%。实际上,块状元素都会以行的形式占据位置。如右侧代码编辑器中三个块状元素标签(div,h1,p)宽度显示为100%。
  • 在流动模型下,内联元素都会在所处的包含元素内从左到右水平分布显示。(内联元素可不像块状元素这么霸道独占一行)

浮动模型

任何元素在默认情况下是不能浮动的,但可以用 CSS 定义为浮动,如 div、p、table、img 等元素都可以被定义为浮动。如下代码可以实现两个 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;}

![](http://upload-images.jianshu.io/upload_images/5276931-3c07575584561a7b.png?imageMogr2/auto-
orient/strip%7CimageView2/2/w/1240)

层模型

层模型有三种形式:

绝对定位(position: absolute)

如果想为元素设置层模型中的绝对定位,需要设置position:absolute(表示绝对定位),这条语句的作用将元素从文档流中拖出来,然后使用left、right、top、bottom属性相对于其最接近的一个具有定位属性的父包含块进行绝对定位。如果不存在这样的包含块,则相对于body元素,即相对于浏览器窗口。
如下面代码可以实现div元素相对于浏览器窗口向右移动100px,向下移动50px。
div{ width:200px; height:200px; border:2px red solid; position:absolute; left:100px; top:50px; } <div id="div1"></div>

相对定位(position: relative)

如果想为元素设置层模型中的相对定位,需要设置position:relative(表示相对定位),它通过left、right、top、bottom属性确定元素在正常文档流中的偏移位置。相对定位完成的过程是首先按static(float)方式生成一个元素(并且元素像层一样浮动了起来),然后相对于以前的位置移动,移动的方向和幅度由left、right、top、bottom属性确定,偏移前的位置保留不动。

如下代码实现相对于以前位置向下移动50px,向右移动100px;
#div1{ width:200px; height:200px; border:2px red solid; position:relative; left:100px; top:50px; } <div id="div1"></div>

固定定位(position: fixed)

fixed:表示固定定位,与absolute定位类型类似,但它的相对移动的坐标是视图(屏幕内的网页窗口)本身。由于视图本身是固定的,它不会随浏览器窗口的滚动条滚动而变化,除非你在屏幕中移动浏览器窗口的屏幕位置,或改变浏览器窗口的显示大小,因此固定定位的元素会始终位于浏览器窗口内视图的某个位置,不会受文档流动影响,这与background-attachment:fixed;属性功能相同。以下代码可以实现相对于浏览器视图向右移动100px,向下移动50px。并且拖动滚动条时位置固定不变。
#div1{ width:200px; height:200px; border:2px red solid; position:fixed; left:100px; top:50px; }<p>文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本。</p>

Relative与Absolute组合使用

相对于其它元素进行定位必须遵守下面规范:

  • 参照定位的元素必须是相对定位元素的前辈元素:
    <div id="box1"> <div id="box2">相对参照元素进行定位</div> </div>
    从上面代码可以看出box1是box2的父元素(父元素当然也是前辈元素了)。

  • 参照定位的元素必须加入position:relative;
    #box1{ width:200px; height:200px; position:relative; }

  • 定位元素加入position:absolute,便可以使用top、bottom、left、right来进行偏移定位了。
    #box2{ position:absolute; top:20px; left:30px; }
    这样box2就可以相对于父元素box1定位了(这里注意参照物就可以不是浏览器了,而可以自由设置了)。

CSS代码优化

盒模型代码优化

外边距(margin)、内边距(padding)和边框(border)设置上下左右四个方向的边距是按照顺时针方向设置的:上右下左。

  • 如果top、right、bottom、left的值相同,可缩写:
    margin:10px;
  • 如果top和bottom值相同、left和 right的值相同,如下面代码:
    margin:10px 20px 10px 20px;
    缩写成:
    margin:10px 20px;
  • 如果left和right的值相同,如下面代码:
    margin:10px 20px 30px 20px;
    可缩写为:
    margin:10px 20px 30px;

颜色值缩写

关于颜色的css样式也是可以缩写的,当你设置的颜色是16进制的色彩值时,如果每两位的值相同,可以缩写一半。

  • 例子1:
    p{color:#000000;}
    可以缩写为:
    p{color: #000;}
  • 例子2:
    p{color: #336699;}
    可以缩写为:
    p{color: #369;}

字体缩写

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; }

  • 使用这一简写方式你至少要指定 font-size 和 font-family 属性,其他的属性(如 font-weight、font-style、font-variant、line-height)如未指定将自动使用默认值。
  • 在缩写时 font-size 与 line-height 中间要加入“/”斜扛。

单位和值

颜色值

  • 英文命令颜色
    p{color:red;}
  • RGB颜色
    p{color:rgb(133,45,200);}
  • 十六进制颜色
    这种颜色设置方法是现在比较普遍使用的方法,其原理其实也是 RGB 设置,但是其每一项的值由 0-255 变成了十六进制 00-ff。
    p{color:#00ffff;}

长度值

  • 像素
    像素为什么是相对单位呢?因为像素指的是显示器上的小点(CSS规范中假设“90像素=1英寸”)。实际情况是浏览器会使用显示器的实际像素值有关,在目前大多数的设计者都倾向于使用像素(px)作为单位。
  • em
    就是本元素给定字体的 font-size 值,如果元素的 font-size 为 14px ,那么 1em = 14px;如果 font-size 为 18px,那么 1em = 18px。如下代码:
    p{font-size:12px;text-indent:2em;}
    上面代码就是可以实现段落首行缩进 24px(也就是两个字体大小的距离)。

注意
但当给 font-size 设置单位为 em 时,此时计算的标准以 p 的父元素的 font-size 为基础。如下代码:
html:
<p>以这个<span>例子</span>为例。</p>
css:
p{font-size:14px} span{font-size:0.8em;}
结果 span 中的字体“例子”字体大小就为 11.2px(14 * 0.8 = 11.2px)

  • 百分比
    p{font-size:12px;line-height:130%}
    设置行高(行间距)为字体的130%(12 * 1.3 = 15.6px)

css样式设置小技巧

水平居中设置-行内元素

行内元素进行水平居中
如果被设置元素为文本、图片等行内元素时,水平居中是通过给父元素设置 text-align:center 来实现的。(父元素和子元素:如下面的html代码中,div是“我想要在父容器中水平居中显示”这个文本的父元素。反之这个文本是div的子元素 )如下代码:
html代码:
<body> <div class="txtCenter">我想要在父容器中水平居中显示。</div> </body>
css代码:
<style> .txtCenter{ text-align:center; } </style>

水平居中设置-定宽块状元素

满足定宽和块状两个条件的元素是可以通过设置“左右margin”值为“auto”来实现居中的。我们来看个例子就是设置 div 这个块状元素水平居中:
<style> div{ border:1px solid red;/*为了显示居中效果明显为 div 设置了边框*/ width:200px;/*定宽*/ margin:20px auto;/* margin-left 与 margin-right 设置为 auto */ } </style>

也可写成:
margin-left:auto; margin-right:auto;

水平居中总结-不定宽块状元素方法(一)

不定宽度的块状元素有三种方法居中(这三种方法目前使用的都很多):

加入[table]标签

为什么选择方法一加入table标签? 是利用table标签的长度自适应性---即不定义其长度也不默认父元素body的长度(table其长度根据其内文本长度决定),因此可以看做一个定宽度块元素,然后再利用定宽度块状居中的margin的方法,使其水平居中。

  • 为需要设置的居中的元素外面加入一个 table 标签 ( 包括 <tbody>、<tr>、<td> )。
  • 为这个 table 设置“左右 margin 居中”(这个和定宽块状元素的方法一样)。
    举例如下:
    html代码:
 <table>
  <tbody>
    <tr><td>
    <ul>
        <li>我是第一行文本</li>
        <li>我是第二行文本</li>
        <li>我是第三行文本</li>
    </ul>
    </td></tr>
  </tbody>
 </table>
</div>```
css代码:
```<style>
  table{
    border:1px solid;
    margin:0 auto;
  }
 </style>```

#####改变元素的display类型为行内元素
改变块级元素的 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,变成了行内元素,所以少了一些功能,比如设定长度值。

#####设置浮动和相对定位来实现
通过给父元素设置[ 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>```

####垂直居中-父元素高度确定的单行文本
我们在实际工作中也会遇到需要设置垂直居中的场景,比如好多报纸的文章标题在左右一侧时,常常会设置为垂直居中,为了用户体验性好。
这里我们又得分两种情况:父元素高度确定的单行文本,以及父元素高度确定的多行文本。
本节我们先来看第一种父元素高度确定的单行文本, 怎么设置它为垂直居中呢?
**父元素高度确定的单行文本**的竖直居中的方法是通过设置父元素的 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>```

#####使用插入 [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,所以我们不需要显式地设置了。

#####设置块级元素的 display 
在 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,破坏了原有的块状元素的性质。

####隐性改变display类型
有一个有趣的现象就是当为元素(不论之前是什么类型元素,display:none 除外)设置以下 2 个句之一:
 *  [position : absolute]
*  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>```

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 7,667评论 1 83
  • 本文主要是起笔记的作用,内容来自慕课网. 认识CSS样式 CSS全称为“层叠样式表 (Cascading Styl...
    0o冻僵的企鹅o0阅读 991评论 0 25
  • CSS格式化排版 1、字体 我们可以使用css样式为网页中的文字设置字体、字号、颜色等样式属性。下面我们来看一个例...
    张文靖同学阅读 282评论 0 3
  • 一 外部式css样式 (也可称为外联式)就是把css代码写一个单独的外部文件中,这个css样式文件以“.css...
    KunMitnic阅读 133评论 0 1
  • 你来了 我敞开藏了太久的 心思 在各样的花瓣上 在大体相同的 蕊中 你看到了吗 这片片白 这淡淡的紫 甚至在道不清...
    本无痕阅读 96评论 14 17