CSS全称为“层叠样式表 (Cascading Style Sheets)”,它主要是用于定义HTML内容在浏览器内的显示样式,如文字大小、颜色、字体加粗等。使用CSS样式的一个好处是经过定义某个样式,可让不一样网页位置的文字有着统一的字体、字号或者颜色等。css
css样式由选择符和声明组成,而声明又由属性和值组成,好比:html
p{color:blue}
就像在Html的注释同样,在CSS中也有注释语句:用/*注释语句*/
来标明(Html中使用<!--注释语句-->
)。chrome
内联式
css样式表就是把css代码直接写在现有的HTML标签中,以下面代码:浏览器
<p style="color:red">这里文字是红色。</p>
注意要写在元素的开始标签里,下面这种写法是错误的:安全
<p>这里文字是红色。</p style="color:red">
而且css样式代码要写在style=""
双引号中,若是有多条css样式代码设置能够写在一块儿,中间用分号隔开。以下代码:编辑器
<p style="color:red;font-size:12px">这里文字是红色。</p>
嵌入式css样式,就是能够把css样式代码写在<style type="text/css"></style>
标签之间。以下面代码实现把三个<span>
标签中的文字设置为红色:布局
<style type="text/css"> span{ color:red; } </style>
嵌入式css样式必须写在<style></style>
之间,而且通常状况下嵌入式css样式写在<head></head>
之间。学习
外部式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样式的位置必定在外部式的后面。如右代码编辑器就是这样,<link href="style.css" ...>
代码在<style type="text/css">...</style>
代码的前面(实际开发中也是这么写的)
其实总结来讲,就是——就近原则(离被设置元素越近优先级别越高)。
但注意上面所总结的优先级是有一个前提:内联式、嵌入式、外部式样式表中css样式是在的相同权值的状况下。
每一条css样式声明(定义)由两部分组成,形式以下:
选择器{ 样式; }
在{}
以前的部分就是“选择器”,“选择器”指明了{}中的“样式”的做用对象,也就是“样式”做用于网页中的哪些元素。
标签选择器其实就是html代码中的标签。如右侧代码编辑器中的<html>
、<body>
、<h1>
、<p>
、<img>
。例以下面代码:
p{font-size:12px;line-height:1.6em;}
上面的css样式代码的做用:为p标签设置12px字号,行间距设置1.6em的样式。
类选择器在css样式编码中是最经常使用到的。
语法:
.类选器名称{css样式代码;}
注意:
英文圆点开头
其中类选器名称能够任意起名(但不要起中文噢)
使用方法:
第一步:使用合适的标签把要修饰的内容标记起来,以下:
<span>胆小如鼠</span>
第二步:使用class="类选择器名称"
为标签设置一个类,以下:
<span class="stress">胆小如鼠</span>
第三步:设置类选器css样式,以下:
.stress{color:red;}/*类前面要加入一个英文圆点*/
在不少方面,ID选择器都相似于类选择符,但也有一些重要的区别:
为标签设置id="ID名称"
,而不是class="类名称"
。
ID选择符的前面是井号(#
)号,而不是英文圆点(.
)。
相同点:
能够应用于任何元素
不一样点:
ID选择器只能在文档中使用一次。与类选择器不一样,在一个HTML文档中,ID选择器只能使用一次,并且仅一次。而类选择器可使用屡次。
可使用类选择器词列表方法为一个元素同时设置多个样式。咱们能够为一个元素同时设多个样式,但只能够用类选择器的方法实现,ID选择器是不能够的(不能使用 ID 词列表)。
下面的代码是正确的(完整代码见右侧代码编辑器)
.stress{ color:red; } .bigsize{ font-size:25px; } <p>到了<span class="stress bigsize">三年级</span>下学期时,咱们班上了一节公开课...</p>
上面代码的做用是为“三年级”三个文字设置文本颜色为红色而且字号为25px。
下面的代码是不正确的(完整代码见右侧代码编辑器)
#stressid{ color:red; } #bigsizeid{ font-size:25px; } <p>到了<span id="stressid bigsizeid">三年级</span>下学期时,咱们班上了一节公开课...</p>
上面代码不能够实现为“三年级”三个文字设置文本颜色为红色而且字号为25px的做用。
还有一个比较有用的选择器子选择器,即大于符号(>
),用于选择指定标签元素的第一代子元素。如右侧代码编辑器中的代码:
.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
标签鼠标滑过的状态设置字体颜色变红。这样就会使第一段文字内容中的“胆小如鼠”文字加入鼠标滑过字体颜色变为红色特效。
当你想为html中多个标签元素设置同一个样式时,可使用分组选择符(,
),以下代码为右侧代码编辑器中的h1
、span
标签同时设置字体颜色为红色:
h1,span{color:red;}
它至关于下面两行代码:
h1{color:red;} span{color:red;}
CSS的某些样式是具备继承性的,那么什么是继承呢?继承是一种规则,它容许样式不只应用于某个特定html标签元素,并且应用于其后代。好比下面代码:如某种颜色应用于p
标签,这个颜色设置不只应用p
标签,还应用于p
标签中的全部子元素文本,这里子元素为span
标签。
p{color:red;} <p>三年级时,我仍是一个<span>胆小如鼠</span>的小女孩。</p>
可见右侧结果窗口中p中的文本与span
中的文本都设置为了红色。但注意有一些css样式是不具备继承性的。如border:1px solid red;
p{border:1px solid red;} <p>三年级时,我仍是一个<span>胆小如鼠</span>的小女孩。</p>
在上面例子中它代码的做用只是给p标签设置了边框为1像素、红色、实心边框线,而对于子元素`span是没用起到做用的。
有的时候咱们为同一个元素设置了不一样的CSS样式代码,那么元素会启用哪个CSS样式呢?咱们来看一下面的代码:
p{color:red;} .first{color:green;} <p class="first">三年级时,我仍是一个<span>胆小如鼠</span>的小女孩。</p>
p
和.first
都匹配到了p
这个标签上,那么会显示哪一种颜色呢?green是正确的颜色,那么为何呢?是由于浏览器是根据权值来判断使用哪一种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,因此能够理解为继承的权值最低。
层叠就是在html文件中对于同一个元素能够有多个css样式存在,当有相同权重的样式存在时,会根据这些css样式的先后顺序来决定,处于最后面的css样式会被应用。
以下面代码:
p{color:red;} p{color:green;} <p class="first">三年级时,我仍是一个<span>胆小如鼠</span>的小女孩。</p>
最后p中的文本会设置为green
,这个层叠很好理解,理解为后面的样式会覆盖前面的样式。
因此前面的css样式优先级就不难理解了:
内联样式表(标签内部)> 嵌入样式表(当前文件中)> 外部样式表(外部文件中)。
咱们在作网页代码的时,有些特殊的状况须要为某些样式设置具备最高权值,怎么办?这时候咱们可使用!important
来解决。
以下代码:
p{color:red!important;} p{color:green;} <p class="first">三年级时,我仍是一个<span>胆小如鼠</span>的小女孩。</p>
这时 p 段落中的文本会显示的red红色。
注意:!important
要写在分号的前面
这里注意当网页制做者不设置css样式时,浏览器会按照本身的一套样式来显示网页。而且用户也能够在浏览器中设置本身习惯的样式,好比有的用户习惯把字号设置为大一些,使其查看网页的文本更加清楚。这时注意样式优先级为:浏览器默认的样式 < 网页制做者样式 < 用户本身设置的样式,但记住!important
优先级样式是个例外,权值高于用户本身设置的样式。
咱们可使用css样式为网页中的文字设置字体、字号、颜色等样式属性。下面咱们来看一个例子,下面代码实现:为网页中的文字设置字体为宋体。
body{font-family:"宋体";}
这里注意不要设置不经常使用的字体,由于若是用户本地电脑上若是没有安装你设置的字体,就会显示浏览器默认的字体。(由于用户是否能够看到你设置的字体样式取决于用户本地电脑上是否安装你设置的字体。)
如今通常网页喜欢设置“微软雅黑”,以下代码:
body{font-family:"Microsoft Yahei";}
或
body{font-family:"微软雅黑";}
注意:第一种方法比第二种方法兼容性更好一些。
由于这种字体即美观又能够在客户端安全的显示出来(用户本地通常都是默认安装的)。
可使用下面代码设置网页中文字的字号为12像素,并把字体颜色设置为#666(灰色):
body{font-size:12px;color:#666}
咱们还可使用css样式来改变文字的样式:粗体、斜体、下划线、删除线,可使用下面代码实现设置文字以粗体样式显示出来。
p span{font-weight:bold;}
在这里你们能够看到,若是想为文字设置粗体是有单独的css样式来实现的,再不用为了实现粗体样式而使用h1
-h6
或strong
标签了。
如下代码能够实现文字以斜体样式在浏览器中显示:
p a{font-style:italic;} <p>三年级时,我仍是一个<a>胆小如鼠</a>的小女孩。</p>
有些状况下想为文字设置为下划线样式,这样能够在视觉上强调文字,可使用下面代码来实现:
p a{text-decoration:underline;} <p>三年级时,我仍是一个<a>胆小如鼠</a>的小女孩。</p>
删除线使用下面代码就能够实现:
.oldPrice{text-decoration:line-through;}
中文文字中的段前习惯空两个文字的空白,这个特殊的样式能够用下面代码来实现:
p{text-indent:2em;} <p>1922年的春天,一个想要成名名叫尼克卡拉威(托比?马奎尔Tobey Maguire 饰)的做家,离开了美国中西部,来到了纽约。那是一个道德感渐失,爵士乐流行,走私为王,股票飞涨的时代。为了追寻他的美国梦,他搬入纽约附近一海湾居住。</p>
注意:2em的意思就是文字的2倍大小。
在段落排版中起重要做用的行间距(行高)属性(line-height),以下代码实现设置段落行间距为1.5倍。
p{line-height:1.5em;} <p>菲茨杰拉德,二十世纪美国文学巨擘之一,兼具做家和编剧双重身份。他以诗人的敏感和戏剧家的想象为"爵士乐时代"吟唱华丽挽歌,其诗人和梦想家的气质亦为那个奢靡年代的不二注解。</p>
中文字间隔、字母间隔设置:
若是想在网页排版中设置文字间隔或者字母间隔就可使用letter-spacing
来实现,以下面代码:
h1{ letter-spacing:50px; } ... <h1>了不得的盖茨比</h1>
注意:这个样式使用在英文单词时,是设置字母与字母之间的间距。
单词间距设置:
若是我想设置英文单词之间的间距呢?可使用word-spacing
来实现。以下代码:
h1{ word-spacing:50px; } ... <h1>welcome to imooc!</h1>
想为块状元素中的文本、图片设置居中样式吗?可使用text-align
样式代码,以下代码可实现文本居中显示。
h1{ text-align:center; } <h1>了不得的盖茨比</h1>
一样能够设置居左:
h1{ text-align:left; } <h1>了不得的盖茨比</h1>
还能够设置居右:
h1{ text-align:right; } <h1>了不得的盖茨比</h1>
在讲解CSS布局以前,咱们须要提早知道一些知识,在CSS中,html中的标签元素大致被分为三种不一样的类型:块状元素、内联元素(又叫行内元素)和内联块状元素。
经常使用的块状元素有:
<div>
、<p>
、<h1>
...<h6>
、<ol>
、<ul>
、<dl>
、<table>
、<address>
、<blockquote>
、<form>
经常使用的内联元素有:
<a>
、<span>
、<br>
、<i>
、<em>
、<strong>
、<label>
、<q>
、<var>
、<cite>
、<code>
经常使用的内联块状元素有:
<img>
、<input>
什么是块级元素?在html中<div>
、<p>
、<h1>
、<form>
、<ul>
和<li>
就是块级元素。设置display:block
就是将元素显示为块级元素。以下代码就是将内联元素a转换为块状元素,从而使a元素具备块状元素特色。
a{display:block;}
块级元素特色:
每一个块级元素都重新的一行开始,而且其后的元素也另起一行。(真霸道,一个块级元素独占一行)
元素的高度、宽度、行高以及顶和底边距均可设置。
元素宽度在不设置的状况下,是它自己父容器的100%(和父元素的宽度一致),除非设定一个宽度。
在html中,<span>
、<a>
、<label>
、 <strong>
和<em>
就是典型的内联元素(行内元素)(inline)元素。固然块状元素也能够经过代码display:inline
将元素设置为内联元素。以下代码就是将块状元素div转换为内联元素,从而使div
元素具备内联元素特色。
div{ display:inline; } ...... <div>我要变成内联元素</div>
内联元素特色:
和其余元素都在一行上;
元素的高度、宽度及顶部和底部边距不可设置;
元素的宽度就是它包含的文字或图片的宽度,不可改变。
内联块状元素(inline-block)就是同时具有内联元素、块状元素的特色,代码display:inline-block
就是将元素设置为内联块状元素。(css2.1新增),<img>
、<input>
标签就是这种内联块状标签。
inline-block
元素特色:
和其余元素都在一行上;
元素的高度、宽度、行高以及顶和底边距均可设置。
盒子模型包括:
padding
容器内边距
margin
盒子的外边距
border
盒子的外边框
特色:
每一个都有四个方向上的边距:top
、bottom
、left
、right
<div>
、<p>
、<ul>
、<ol>
都是块级标签,盒子模型的特征只适合块级标签。
注:盒子的实际宽度=左边界+左边框+左填充+内容宽度+右填充+右边框+右边界(内容高度+上下内外边距),高度同理。
盒子模型的边框就是围绕着内容及补白的线,这条线你能够设置它的粗细、样式和颜色(边框三个属性)。
以下面代码为div
来设置边框粗细为2px、样式为实心的、颜色为红色的边框:
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)。
如今有一个问题,若是有想为 p 标签单独设置下边框,而其它三边都不设置边框样式怎么办呢?css 样式中容许只为一个方向的边框设置样式:
div{border-bottom:1px solid red;}
一样可使用下面代码实现其它三边(上、右、左)边框的设置:
border-top:1px solid red; border-right:1px solid red; border-left:1px solid red;
盒模型宽度和高度和咱们日常所说的物体的宽度和高度理解是不同的,css内定义的宽(width)和高(height),指的是填充之内的内容范围。
所以一个元素实际宽度(盒子的宽度)=左边界+左边框+左填充+内容宽度+右填充+右边框+右边界。
元素的高度也是同理。
好比:
css代码:
div{ width:200px; padding:20px; border:1px solid red; margin:10px; }
html代码:
<body> <div>文本内容</div> </body>
元素的实际长度为:10px+1px+20px+200px+20px+1px+10px=262px。
元素内容与边框之间是能够设置距离的,称之为“填充”。填充也可分为上、右、下、左(顺时针)。以下代码:
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;}
元素与其它元素之间的距离可使用边界(margin)来设置。边界也是可分为上、右、下、左。以下代码:
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 盒模型的基本概念、 盒模型类型, 咱们就能够深刻探讨网页布局的基本模型了。布局模型与盒模型同样都是 CSS 最基本、 最核心的概念。 但布局模型是创建在盒模型基础之上,又不一样于咱们常说的 CSS 布局样式或 CSS 布局模板。若是说布局模型是本,那么 CSS 布局模板就是末了,是外在的表现形式。
CSS包含3种基本的布局模型,用英文归纳为:Flow
、Layer
和Float
。
在网页中,元素有三种布局模型:
流动模型(Flow
)
浮动模型(Float
)
层模型(Layer
)
先来讲一说流动模型,流动(Flow)是默认的网页布局模式。也就是说网页在默认状态下的 HTML 网页元素都是根据流动模型来分布网页内容的。
流动布局模型具备2个比较典型的特征:
第一点,块状元素都会在所处的包含元素内自上而下按顺序垂直延伸分布,由于在默认状态下,块状元素的宽度都为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;}
什么是层布局模型?层布局模型就像是图像软件PhotoShop中很是流行的图层编辑功能同样,每一个图层可以精肯定位操做,但在网页设计领域,因为网页大小的活动性,层布局没能受到热捧。可是在网页上局部使用层布局仍是有其方便之处的。下面咱们来学习一下html中的层布局。
如何让html元素在网页中精肯定位,就像图像软件PhotoShop中的图层同样能够对每一个图层可以精肯定位操做。CSS定义了一组定位(positioning
)属性来支持层布局模型。
层模型有三种形式:
绝对定位(position: absolute
)
相对定位(position: relative
)
固定定位(position: fixed
)
若是想为元素设置层模型中的绝对定位,须要设置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> ....
使用position:absolute
能够实现被设置元素相对于浏览器(body)设置定位之后,你们有没有想过可不能够相对于其它元素进行定位呢?答案是确定的,固然能够。使用position:relative
来帮忙,可是必须遵照下面规范:
1.参照定位的元素必须是相对定位元素的前辈元素:
<div id="box1"><!--参照定位的元素--> <div id="box2">相对参照元素进行定位</div><!--相对定位元素--> </div>
从上面代码能够看出box1是box2的父元素(父元素固然也是前辈元素了)。
2.参照定位的元素必须加入position:relative
;
#box1{ width:200px; height:200px; position:relative; }
3.定位元素加入position:absolute
,即可以使用top
、bottom
、left
、right
来进行偏移定位了。
#box2{ position:absolute; top:20px; left:30px; }
这样box2就能够相对于父元素box1定位了(这里注意参照物就能够不是浏览器了,而能够自由设置了)。
还记得在讲盒模型时外边距(margin
)、内边距(padding
)和边框(border
)**设置上下左右四个方向的边距是按照顺时针方向设置的:上右下左。具体应用在margin
和padding
的例子以下:
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
是一致的。
关于颜色的css样式也是能够缩写的,当你设置的颜色是16进制的色彩值时,若是每两位的值相同,能够缩写一半。
例子1:
p{color:#000000;}
能够缩写为:
p{color: #000;}
例子2:
p{color: #336699;}
能够缩写为:
p{color: #369;}
网页中的字体css样式代码也有他本身的缩写方式,下面是给网页设置字体的代码:
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-varient
、line-height
)如未指定将自动使用默认值。
二、在缩写时font-size
与line-height
中间要加入“/
”斜扛。
通常状况下由于对于中文网站,英文仍是比较少的,因此下面缩写代码比较经常使用:
body{ font:12px/1.5em "宋体",sans-serif; }
只是有字号、行间距、中文字体、英文字体设置。
在网页中的颜色设置是很是重要,有字体颜色(color
)、背景颜色(background-color
)、边框颜色(border
)等,设置颜色的方法也有不少种:
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;}
配色表:
长度单位总结一下,目前比较经常使用到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(也就是两个字体大小的距离)。(indent英文义为「切割…使呈锯齿状; 缩进排版」。)
下面注意一个特殊状况:
但当给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)。
3.百分比
p{font-size:12px;line-height:130%}
设置行高(行间距)为字体的130%(12 * 1.3 = 15.6px)。
若是被设置元素为文本、图片等行内元素时,水平居中是经过给父元素设置text-align:center
来实现的。以下代码:
html代码:
<body> <div class="txtCenter">我是文本,哈哈,我想要在父容器中水平居中显示。</div> </body>
css代码:
<style> div.txtCenter{ text-align:center; } </style>
当被设置元素为块状元素时用text-align:center
就不起做用了,这时也分两种状况:定宽块状元素和不定宽块状元素。这一小节咱们先来说一讲定宽块状元素。
知足定宽和块状两个条件的元素是能够经过设置“左右margin
”值为“auto
”来实现居中的。咱们来看个例子就是设置div
这个块状元素水平居中:
html代码:
<body> <div>我是定宽块状元素,哈哈,我要水平居中显示。</div> </body>
css代码:
<style> div{ border:1px solid red;/*为了显示居中效果明显为 div 设置了边框*/ width:500px;/*定宽*/ margin:20px auto;/* margin-left 与 margin-right 设置为 auto */ } </style>
也能够写成:
margin-left:auto; margin-right:auto;
注意:元素的“上下 margin
” 是能够随意设置的。(margin
:外边距属性)
不定宽度的块状元素有三种方法居中(这三种方法目前使用的都比多):
加入table
标签
设置display;inline
方法
设置position:relative
和left:50%
;
这一小节咱们来说一下第一种方法:
第一步:为须要设置的居中的元素外面加入一个table
标签 ( 包括<tbody>
、<tr>
、<td>
)。
第二步:为这个table
设置“左右margin居中
”(这个和定宽块状元素的方法同样)。
html代码:
<div> <table> <tbody> <tr><td> <ul> <li><a href="#">1</a></li> <li><a href="#">2</a></li> <li><a href="#">3</a></li> </ul> </td></tr> </tbody> </table> </div>
css代码:
<style> table{ margin:0 auto; } ul{list-style:none;margin:0;padding:0;} li{float:left;display:inline;margin-right:8px;} </style>
第二种方法:改变块级元素的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; } .container ul{ list-style:none; margin:0; padding:0; display:inline; } .container li{ margin-right:8px; display:inline; } </style>
这种方法相比第一种方法的优点是不用增长无语义标签,简化了标签的嵌套深度,但也存在着一些问题:它将块状元素的display
类型改成inline
,变成了行内元素,因此少了一些功能,好比设定长度值。
方法三:经过给父元素设置float
,而后给父元素设置position:relative
和 left:50%
,子元素设置position:relative
和left:-50%
来实现水平居中。
代码以下:
<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>
这种方法能够保留块状元素仍以display:block
的形式显示,优势不添加无语议表标签,不增长嵌套深度,但它的缺点是设置了position:relative
,带来了必定的反作用。
父元素高度肯定的单行文本的竖直居中的方法是经过设置父元素的height
和line-height
高度一致来实现的。以下代码:
<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
,但这个样式只有在父元素为td
或th
时,才会生效。因此又要插入table
标签了。下面看一下例子:
html代码:
<body> <table><tbody><tr><td class="wrap"> <div> <p>看我是否能够居中。</p> <p>看我是否能够居中。</p> <p>看我是否能够居中。</p> <p>看我是否能够居中。</p> <p>看我是否能够居中。</p> </div> </td></tr></tbody></table> </body>
css代码:
table td{height:500px;background:#ccc}
由于td
标签默认状况下就默认设置了vertical-align
为middle
,因此咱们不须要显式地设置了。
在 chrome、firefox 及 IE8 以上的浏览器下能够设置块级元素的display
为table-cell
,激活vertical-align
属性,但注意 IE六、7 并不支持这个样式。
html代码:
<div class="container"> <div> <p>看我是否能够居中。</p> <p>看我是否能够居中。</p> <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>
这种方法的好处是不用添加多余的无心义的标签,但缺点也很明显,它的兼容性不是很好,不兼容 IE六、7。
有一个有趣的现象就是当为元素(不论以前是什么类型元素,display:none
除外)设置如下 2 个句之一:
position : absolute
float : left
或 float:right
元素会自动变为以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>