社区微信群开通啦,扫一扫抢先加入社区官方微信群
社区微信群
本课来自http://www.imooc.com/learn/9
请不要用作商业用途。
<html> <head>...</head> <body>...</body> </html>
下面这些标签可用在 head 部分:<head> <title>...</title> <meta> <link> <style>...</style> <script>...</script> </head>
``
<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 />
是规范的写法,这是一个空标签,只有开始标签,没有结束标签
 ;
表示空格
<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表格在没有添加css样式之前,在浏览器中显示是没有表格线的<tbody>…</tbody>
当表格内容非常多时,表格会下载一点显示一点,但如果加上<tbody>标签后,这个表格就要等表格内容全部下载完才会显示<tr>…</tr>
表格的一行,所以有几对tr 表格就有几行<td>…</td>
表格的一个单元格,一行中包含几对td,说明一行中就有几列<th>…</th>
表格的头部的一个单元格,表格表头,th标签中的文本默认为粗体并且居中显示<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>
mailto
如果mailto后面同时有多个参数的话,第一个参数必须以“?”开头,后面的参数每一个都以“&”分隔。
example:
<img>
![](图片地址)
<form method="传送方式" action="服务器文件">
<form> <input type="text/password" name="名称" value="文本" /> </form>
<textarea rows="行数" cols="列数">文本</textarea>
<textarea>
<textarea>标签是成对出现的,以<textarea>开始,以</textarea>结束。
cols :多行输入域的列数
rows :多行输入域的行数
<input type="radio/checkbox" value="值" name="名称" checked="checked"/>
value:
多选操作:
设置multiple="multiple"属性,就可以实现多选功能
<input type="reset" value="重置">
value:按钮上显示的文字
<label>
<label for="控件id名称">
label标签不会向用户呈现任何特殊效果,它的作用是为鼠标用户改进了可用性。如果你在 label 标签内点击文本,就会触发此控件。就是说,当用户单击选中该label标签时,浏览器就会自动将焦点转到和标签相关的表单控件上(就自动选中和该label标签相关连的表单控件上)标签的 for 属性中的值应当与相关控件的 id 属性值一定要相同
CSS全称为“层叠样式表 (Cascading Style Sheets)”,它主要是用于定义HTML内容在浏览器内的显示样式,如文字大小、颜色、字体加粗等p{ font-size:12px; color:red; font-weight:bold; }
p{font-size:12px;color:red;}
和C++一样
<p style="color:red;font-size:12px">这里文字是红色。</p>
实现把三个<span>标签中的文字设置为红色:<style type="text/css"> span{ color:red; } </style>
外部式css样式(也可称为外联式)就是把css代码写一个单独的外部文件中,这个css样式文件以“.css”为扩展名,在<head>内(不是在<style>标签内)使用<link>标签将css样式文件链接到HTML文件内,如下面代码:<link href="base.css" rel="stylesheet" type="text/css" />
在相同权值的情况下,就是--就近原则(离被设置元素越近优先级别越高)
每一条css样式声明(定义)由两部分组成,形式如下:选择器{ 样式; }
在{}之前的部分就是“选择器”,“选择器”指明了{}中的“样式”的作用对象,也就是“样式”作用于网页中的哪些元素
.类选器名称{css样式代码;}
<span>胆小如鼠</span>
<span class="stress">胆小如鼠</span>
.stress{color:red;}/*类前面要加入一个英文圆点*/
可以应用于任何元素
子选择器,即大于符号(>),用于选择指定标签元素的第一代子元素.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的某些样式是具有继承性的,那么什么是继承呢?继承是一种规则,它允许样式不仅应用于某个特定html标签元素,而且应用于其后代。比如下面代码:p{color:red;} <p>三年级时,我还是一个<span>胆小如鼠</span>的小女孩。</p>
浏览器是根据权值来判断使用哪种css样式的,权值高的就使用哪种css样式。
层叠就是在html文件中对于同一个元素可以有多个css样式存在,当有相同权重的样式存在时,会根据这些css样式的前后顺序来决定,处于最后面的css样式会被应用
我们可以使用!important来为某些样式设置具有最高权值p{color:red!important;} p{color:green;} <p class="first">三年级时,我还是一个<span>胆小如鼠</span>的小女孩。</p>
注意:!important要写在分号的前面
浏览器默认的样式 < 网页制作者样式 < 用户自己设置的样式,但记住!important优先级样式是个例外,权值高于用户自己设置的样式
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;}
h1{ letter-spacing:50px; } <h1>了不起的盖茨比</h1>
注意:这个样式使用在英文单词时,是设置字母与字母之间的间距。
h1{ word-spacing:50px; } <h1>welcome to imooc!</h1>
使用text-align样式代码,如下代码可实现文本居中显示h1{ text-align:center; } <h1>了不起的盖茨比</h1>
<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;}
块状元素也可以通过代码display:inline将元素设置为内联元素,如下代码就是将块状元素div转换为内联元素,从而使 div 元素具有内联元素特点div{ display:inline; }
代码display:inline-block就是将元素设置为内联块状元素
盒子模型的边框就是围绕着内容及补白的线,这条线你可以设置它的粗细、样式和颜色(边框三个属性)div{ border-width:2px; border-style:solid; border-color:red; }
border-color:#888;//前面的井号不要忘掉
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包含3种基本的布局模型,用英文概括为:Flow、Layer 和 Float。
在网页中,元素有三种布局模型:
先来说一说流动模型,流动(Flow)是默认的网页布局模式。也就是说网页在默认状态下的 HTML 网页元素都是根据流动模型来分布网页内容的。
任何元素在默认情况下是不能浮动的,但可以用 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(表示绝对定位),这条语句的作用将元素从文档流中拖出来,然后使用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(表示相对定位),它通过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>
fixed:表示固定定位,与absolute定位类型类似,但它的相对移动的坐标是视图(屏幕内的网页窗口)本身。由于视图本身是固定的,它不会随浏览器窗口的滚动条滚动而变化,除非你在屏幕中移动浏览器窗口的屏幕位置,或改变浏览器窗口的显示大小,因此固定定位的元素会始终位于浏览器窗口内视图的某个位置,不会受文档流动影响,这与background-attachment:fixed;属性功能相同。以下代码可以实现相对于浏览器视图向右移动100px,向下移动50px。并且拖动滚动条时位置固定不变。#div1{ width:200px; height:200px; border:2px red solid; position:fixed; left:100px; top:50px; }<p>文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本。</p>
相对于其它元素进行定位必须遵守下面规范:
参照定位的元素必须是相对定位元素的前辈元素:<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定位了(这里注意参照物就可以不是浏览器了,而可以自由设置了)。
外边距(margin)、内边距(padding)和边框(border)设置上下左右四个方向的边距是按照顺时针方向设置的:上右下左。
margin:10px;
margin:10px 20px 10px 20px;
margin:10px 20px;
margin:10px 20px 30px 20px;
margin:10px 20px 30px;
关于颜色的css样式也是可以缩写的,当你设置的颜色是16进制的色彩值时,如果每两位的值相同,可以缩写一半。
p{color:#000000;}
p{color: #000;}
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; }
p{color:red;}
p{color:rgb(133,45,200);}
p{color:#00ffff;}
p{font-size:12px;text-indent:2em;}
注意
但当给 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%}
行内元素进行水平居中
如果被设置元素为文本、图片等行内元素时,水平居中是通过给父元素设置 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标签的长度自适应性---即不定义其长度也不默认父元素body的长度(table其长度根据其内文本长度决定),因此可以看做一个定宽度块元素,然后再利用定宽度块状居中的margin的方法,使其水平居中。
<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>```
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!