基本
常识与实践
链接方式
基本
最基本的方式就是直接在html文件中指定元素样式,这种方式不推荐,因为将表现层和结构层混起来了
"style="background-image:url({{user.avatar}})"
内部链接
要为html直接增加css样式,需要在元素中增加开始和结束style标记,css规则放在里面
<style>
p {
color: gray
}
</style>
css文件外置
另一种方式将css文件外置,如style.css,作为样式表(stylesheets),然后从html众创建一个到这个文件的外部链接,用元素,用外部样式表的好处是要修改整个网站的样式,只要进入这个样式表,对css进行几处修改即可。如:
<link type="text/css" rel="stylesheet" href="lounge.css" >
多样式表
使用多个样式表,顺序很重要,一个样式表会覆盖在它上面链接的样式表中的样式,有时会有一个样式表作为页面的基础样式,要修改样式,链接这个样式表,然后在下面提供自己的样式表,指定要修改的样式,如下所示:
<link rel="stylesheet" href="corperate.css">//总公司样式
<link rel="stylesheet" href="beverage-division.css">//部门对总公司的样式做了一些补充,甚至可以覆盖公司的样式
<link rel="stylesheet" href="lounge-seattle.css">//西雅图休闲室对样式表做了自己的调整
简写
css属性太多,能不能不费吹灰之力就指定这些属性呢?可以把同一属性的值结合起来写成一句,即简写。
简写格式
padding
padding: 0px 40px 30px 20px,顺序是上右下左,顺时针有木有,如果都相同可以用padding: 20px
padding-top: 0px
padding-right: 40px
padding-bottom:30px
padding-left: 20px
margin
上面的padding格式同样对margin也适用,还有另一种方法,如果上下一样,左右一致,可以这样写:margin: 0px 20px,前面指定上下,后面指定左右。
border
边框属性简写 border: thin solid #007e73,可以用你喜欢的任何顺序。
background
背景简写 background: white url(images/cocktail.gif) repeat-x,同样顺序随便
字体
字体简写的格式稍微复杂一些:
font : font-style font-variant font-weight font-size/line-height font-family
选择
子孙选择器
父元素和子孙元素名之间有一个空格,子孙选择器会选择所有子孙,包括这个元素中嵌套的所有,不管嵌套多深,例如
color: black
}
直接孩子
如果要选择直接的孩子,用>
color: black
}
复杂选择
更复杂的选择,方法还是一样
color: blue
}
规则添加
类
当我们用选择器选择元素使用一个规则时,会对所有该元素应用这个样式,所以如何单独地选择这些元素呢?这里就需要类class,class可以定义一类元素,对属于该类的所有元素应用样式.要将一个元素加入一个类,只需要增加属性”class”,并提供类名,如”greentea”:
<p class="greentea">
...
</p>
类元素选择器
先选择这个类中的元素,再用”.”指定一个类,最后是类名,如:
p.greentea {
color: green
}
添加类元素
如果想对所有<blockquote>也做同样的处理,可以:
blockquote.greentea,p.greentea {
color: green
}
<blockquote class = "greentea">
类选择器
如果想把<h1>,<h2>,<h3>,<p>和<blockquote>都增加到greentea呢?要对类中的所有元素都用同一样式可以用:
.greentea{
color: green
}
/ 省略所有元素名,只有一个点,则会应用到所有成员 /
多类元素
元素可以有多个类,例如:
<p class="greentea raspberry blueberry"
特定元素选择器
如果多个选择器都选择了一个元素呢?例如上面的3个类都与p元素匹配,并且都定义了color属性,那么那个会胜出?
id
id的作用
id属性用来唯一地命名元素,通常你想对多个元素重用某些样式,才能真正发挥类的作用。但是如果只有一个元素需要样式,或者页面上只有一个元素,那就应该使用id,每个元素只能有一个id,页面中只能有一个元素拥有特定id,一个元素有一个id,同时可以属于一个或多个类,id中不允许出现空格或其他特殊字符,如
<p id="footer">...</p>
选择元素
用id选择一个元素,需要在id前面使用一个#字符(类是[.]),id选择器只与页面中的一个元素匹配
color: red
}//选择id为footer的任意元素
p#footer{
color: red
}//选择id为footer的<p>元素
实践建议
继承
样式继承
层叠
媒体查询
link媒体查询
你可能想针对将要显示页面的设备调整页面的样式,可以用media属性,在link元素中增加这个属性.如
<link rel="stylesheet" href="lounge-mobile.css" mdeia="screen and (max-device-width: 480px)">
<link rel="stylesheet" href="lounge-print.css" media="print">
css媒体查询
可以直接在css中增加媒体查询,使用@media规则,把对所有媒体类型都通用的规则放在@media规则下面,例如
@media screen and (min-device-width: 481px){//当设备屏幕宽度大于480px时使用
margin-right: 250px
}
}
@media screen and (max-device-width: 480px){//当设备屏幕小于等于480px时使用
margin-right: 30px
}
}
@media print { // 如果要打印页面,使用该规则
body {
font-family: Times, "Times New Roman", serif
}
}
实践建议
属性
盒模型
盒模型是css看待元素的一种方式,css将每个元素看作由一个盒子表示,每个盒子由一个内容区以及可选的内边距,边框和外边距组成。由内而外分别是:
border 边框
color 颜色
文本元素的字体颜色
body{
background-color: rgb(80%, 40% , 0%)//橙色
}
还可以指定0-255之间的一个数值,例如:
body{
background-color: rgb(204, 102, 0)//和上面颜色一致,255*80% = 204...
}
font-family 字体
大多数计算机上通常只安装了部分字体,所以选择字体时要当心,通常指定的font-family包含一个候选字体列表,他们都来自同一个字体系列,候选字体用逗号分隔,大小写字母必须一致,最后总是放一个通用的字体系列名,如果一个字体名中包含多个单词,比如Courier New,如何指定?用引号,”Courier New”,如:
body{
font-family: Verdana, Geneva, Arial, sans-serif<一一首选字体呈降序
}
字体系列
每个font-family包含一组有共同特征的字体。共有5个字体系列:
body { font-size : small}
h1 { font-size : 150%}
h2 { font-size : 120%}
注意老版IE不支持用像素指定的文本缩放
浏览器默认字体大小
其他属性
left 指定一个元素的左边所在位置
top 控制一个元素顶部的位置
background-image 在元素后面放置一个图像,如
background-image: url(images/background.gif)
//用url括起来,注意没有引号
background-repeat 背景图像是否重复
line-height: 1//代表elixirs中的所有元素的行间距为其自己字体大小的1倍
}
width: 200px
float: right
}
background-color: #675c47
color:#efe5d0
text-align: center
padding: 15px
margin: 10px
font-size:90%
clear:right
}
width: 800px
padding-top: 5px
padding-bottom: 5px
background-color: #675c47
}
那么页面的宽度将被限制为800px,无论浏览器宽度如何变化都不会移动,但这会导致浏览器很宽时,右边有很多空白空间
凝胶布局 Jello
width: 800px
padding-top: 5px
padding-bottom: 5px
background-color: #675c47
margin-left: auto
margin-right: auto
}
绝对定位
position: absolute
top: 100px
right: 200px
width: 280px
}
display: table
border-spacing: 10px//于是不再需要div中的外边距
}
display: table-row
}
display: table-cell
background: #efe5d0 url(images/background.gif) top left
font-size:105%
padding: 15px
/ margin: 0px 10px 10px 10px/
vertical-align: top//确保表格两个单元格中的所有内容相对于单元格上边对齐,默认为中间对齐,可以设置为top,middle,bottom
}
display: table-cell
background: #efe5d0 url(images/background.gif) bottom right
font-size:105%
padding: 15px
/ margin: 0px 10px 10px 10px/
vertical-align: top
}
之前只是认为z-index只是简单的值越大就越靠近观察者,越在上层。直到今天因为面试才发现不是这么简单的。在css世界中z-index属性只有和定位元素(position不为static的元素)在一起的时候才起作用,可以是整数或者负数。理论上,数值越大层级越高,但实际上其规则要复杂的多。但随着css3的到来,flex盒子的子元素也可以设置z-index属性。
要知道网页中绝大部分并不是定位元素,并且影响层叠顺序的不止z-index一个,z-index只是css层叠规则中的一叶扁舟。
所谓的层叠规则是指的当前网页中的元素发生层叠时的表现规则。
层叠上下文(stacking context):是HTML中一个三维的概念。在CSS2.1规范中,每个盒模型的位置是三维的,分别是平面画布上的X轴,Y轴以及表示层叠的Z轴。一般情况下,元素在页面上沿X轴Y轴平铺,我们察觉不到它们在Z轴上的层叠关系。而一旦元素发生堆叠,这时就能发现某个元素可能覆盖了另一个元素或者被另一个元素覆盖。
如果一个元素含有层叠上下文,(也就是说它是层叠上下文元素),我们可以理解为这个元素在Z轴上就“高人一等”,最终表现就是它离屏幕观察者更近。
层叠水平(stackinge-level):决定了同一个层叠上下文中元素在z轴上的显示顺序。所有的元素多有层叠水平,包括普通元素,包括层叠上下文环境。
层叠顺序(stacking order):表示元素发生层叠时有着特定的垂直显示顺序,层叠规则。
默认的堆叠规则,即不含有 z-index 属性时:
对于浮动的块元素来说,层叠顺序变得有些不同。浮动块元素被放置于非定位元素与定位元素之间:
z-index属性的值只能是整数(正负均可)
在下一个例子中, 所有的层都是用z-index进行排序的。 元素div#5 的z-index无效, 因为他没有被指定position属性
在之前的[增加 z-index] 的例子中, 某些 DIV 的渲染顺序是由 z-index 的值影响的。这是因为这些 DIV 具有 使他们形成一个 层叠上下文 的特殊属性 。
在层叠上下文中,其子元素同样也按照上面解释的规则进行层叠。 特别值得一提的是,其子元素的 z-index 值只在父级层叠上下文中有意义。子级层叠上下文被自动视为父级层叠上下文的一个独立单元。
DIV+CSS规则整理一、善用css缩写规则
/*注意上、右、下、左的书写顺序*/
1. 关于边距(4边):
1px 2px 3px 4px (上、右、下、左)
1px 2px 3px (省略的左等于右)
1px 2px (省略的上等于下)
1px (四边都相同)
2. 简化所有:
*/ body{margin:0}------------表示网页内所有元素的margin为0
#menu{ margin:0}------------表示menu盒子下的所有元素的margin为0
3. 缩写(border)特定样式:
Border:1px solid #ffffff
Border-width:0 1px 2px 3px
4. 关于文字的缩写规则:
Font-style:italic斜体形式
Font-variant:small-caps/normal变体样式:小型大写字母/正常
Font-weight:bold
Font-size:12px
Line-height:1.2em(120%)/1.5em(150%)
Font-family:arrial,sans-serif,verdana
缩写成:
Font:italic small-caps bold 12px/1.5emarrial,sans-serif
注意:Font-size和Line-height用斜杠组合在一起不能分开写。
5. 关于背景图片的:
Background:#FFF url(log.gif) no-repeatfixed top left
6. 关于列表:
List-style-type:square/none
List-style-position:inside
List-style-image:url(filename.gif)
缩写成:
List-style:none inside url(filename.gif)
二、运用4种方法来引入CSS样式
1.link
<link rel=”stylesheet” type=”text/css”href=”a.css”>
rel 关系
type 数据类型,有多种
href 路径
部分浏览器支持候选样式,关键字:alternate:
<link rel=”stylesheet” type=”text/css”href=”a.css”>
<link rel=”alternate stylesheet”type=”text/css” href=”b.css”>
<link rel=”alternate stylesheet”type=”text/css” href=”c.css”>
2.内部样式块
<style>
<!–
h1{color:red}
–>
</style>
3.@import
@import url{a.css}
注意:此指令必须放在<style>容器中,并且在所有样式之前
建议放在一个html注释中,<!– –>浏览器会不显示注释内的内容,而import等css代码能正常工作
4.内联样式
<p style=”color:red”>
选择器是css的一个基本概念,基本规则如下:
1.规则结构:
h1 {color:red}
选择器 {属性:值}
这类是元素选择器,基本可以包括所有html的元素
属性值可以包括多个元素,如:border:1px solid red
常用语法
1)分组:
选择器和声明都可以分组:
h1,h2,h3{color:redbackground:#fff} ,选择器用“,”分割开,属性用””分割
2)类选择器,即通过class=”stylename”应用的声明
定义:
.stylename{color:red}
注意:
在html中可以使用多类选择:如class=”cn1 cn2 cn3″
3)ID选择器,即与id属性对应的样式
定义:
#a{color:red} ->这个定义对用id=”a”的元素
2.这部分都是我们常见的css语法,下面谈一下我们不常见的选择器语法
1)父子结构,跟文档结构图对应
如p span{border:1px solidred}对应的是<p>下面的<li>标签,这个很用用途,可以准确定位.
一些特殊应用(IE7支持):
(1) p >span{},匹配所有p下所有的span
(2) p + span{} ,匹配紧接着p元素后出现的第一个span标签,2者要有相同的父标签
2)属性选择器:(注意:属性选择器ie7才开始支持,以下版本并不支持,其他的浏览器基本可以)
语法:img[alt]{border:1pxsolid}
表示对应有alt属性的img标签,当然可以支持多个属性对应,如img[alt][title]{}表示这个2个属性都有的img标签,
也可以与具体值对应:如:img[alt=”摄影”]{}
属性选择器中的高级应用,特殊匹配:
(1)img[class~=”b”], ~= : 与属性中的一个值对应的,即与<img class=”a b c”>对应
(2)[class^=”a”],以a开头的
(3)[class$=”a”],以a结束的
(4)[class*=”a”],包含a的
(5)[class|=”a”],等于a或以a开头的
3)伪类和伪元素
日常使用中主要是<a>标签的几个伪类:link:hover:active:visited
以及:first-child:first:before:left:right:lang:focus:fist-line等等
注意:动态伪类可以应用到任何元素,如,input:focus{background:red}当input标签获得焦点时背景变红
以上语法组合使用,就能实现定位准确、简单间接的样式了。
三、选择器分类整合
优先级别遵循:行内样式 >ID >Class >标记
基本选择器标记选择器(eg:<p></p>)
类别选择器(eg:class)
ID选择器
复合选择器
“交集”复合选择器(eg:p.menu{color:red})必须是
标记+类别/ID组合
“并集”复合选择器(eg:h1,h2,h3{color:red})
“后代”复合选择器(eg: #menu.menulist{ ... })
“子”复合选择器(eg: #menu.menulist .selectit {... })
四、使用子选择器减少id和class的定义
示例结构:
<div id="menu">
<div class="menulist">
<divclass="selectit">content</div>
</div>
</div>
示例CSS:
#menu { ... }
#menu .menulist { ... }
#menu .menulist .selectit { ... }
五、使用组选择器为不同元素应用相同的样式
如h1,h2,h3,div{font-size:16pxfont-weight:bold}
则h1,h2,h3,div元素的样式都为字体16像素,字体粗体
六、伪类和选择符的配合使用
将伪类和类组合起来用,就可以在同一个页面中做几组不同的链接效果了,例如,我们定义一组链接为红色,
访问后为蓝色;另一组为绿色,访问后为黄色:
a.red:link {color: #FF0000}
a.red:visited {color: #0000FF}
a.blue:link {color: #00FF00}
a.blue:visited {color: #FF00FF}
现在应用在不同的链接上:
<a class="red"href="...">这是第一组链接</a>
<a class="blue" href="...">这是第二组链接</a>
七、CSS的最近优先原则
/*如果对一个元素定义了多次样式,则以最近的一级优先,最近一级的样式将覆盖其他行内样式 >ID >Class>标记*/
以下是引用片段:
CSS:
p{color:red}
.blue{color:blue}
.yellow{color:yellow}
HTML:
<p>此处显示为红色</p>
<p class="blue">此处显示为蓝色</p>
<p class="blue"style="color:green">此处显示为绿色</p>
<p class="blue yellow">此处显示为黄色</p>
注意:
(1)注意样式的几个优先顺序(优先级由上至下递减,下面的样式覆盖上面的样式):
--元素style设定
--head区<style></style>中的设定
--外部引用css文件
(2)优先级不是按访问顺序来设定的,而是又css中的声明顺序来设的。
如上例中<pclass="yellow blue">此处显示为黄色</p>也显示为黄色,因为在css定义中.yellow在.blue
的后面。
八、书写正确的链接样式
当用css定义链接的各种状态时,要注意书写的顺序即::link :visited :hover :active利用首字母:L V H A,
你可以通过记忆LoVe,Hate,两个单词来记住其顺序。
:link --------链接的颜色
:visited -----鼠标点击后的颜色
:hover -------鼠标放上去未点的颜色(悬停)
:active-------鼠标点击瞬间的颜色
九、:hover的灵活运用
IE6不支持除a标签以外的:hover属性,我们了解:hover属性是鼠标悬停效果。在IE7和FF中,对几乎任意元素
都可以设置:hover属性效果。这对我们做不同的访问效果很好。
如:
p {
width : 360px
height : 80px
padding : 20px
margin : 50px auto 0 auto
border : 1px solid #ccc
line-height : 25px
background : #fff
}
p:hover {
border : 1px solid #000
background : #ddd
}
----------------此效果针对IE7和FF
p a {
color : #00f
text-decoration : none
font-size : 13px
}
p a:hover {
color : #036
text-decoration : underline
}
-----------------此效果针对IE6
十、定义A标签要注意的小问题
当我们定义a{color:red}时,它代表了A的四种状态的样式,如果此时要定义一个鼠标放上的状态只要定义
a:hover就可以了,其它三种状态就是A中所定义的样式。
只定义了一个a:link时,一定要记得把其它三种状态定义出来!
十一、禁止内容换行与强制内容换行
在表格或层中我们可能希望内容不换行或强制换行,我们可以通过一些css属性来达到这些要求。
禁止换行:white-space:nowrap
强制换行:word-break:break-allwhite-space: normal
十二、区别relative和absolute
Absolute---CSS中的写法是:position:absolute他的意思是绝对定位,他是参照浏览器的左上角,配合
TOP、RIGHT、BOTTOM、LEFT(下面简称TRBL)进行定位,在没有设定TRBL,默认依据父级的做标原始点为
原始点。如果设定TRBL并且父级没有设定position属性,那么当前的absolute则以浏览器左上角为原始点进行
定位,位置将由TRBL决定。
Relative---CSS中的写法是:position:relative他的意思是绝对相对定位,他是参照父级的原始点为原始点,
无父级则以BODY的原始点为原始点,配合TRBL进行定位,当父级内有padding等CSS属性时,当前级的原始
点则参照父级内容区的原始点进行定位。
十三、区别块级元素block和内联元素inline
块级---可定义宽高,另起独占一行(如:divul)
内联---不可定义宽高,如文本元素(如a span)
十四、区别display和visibility
display:none和visibility:hidden都可以隐藏一个元素,但visibility:hidden只是隐藏了元素的内容,但其使用的
位置空间仍然被保留。而display:none则相当把元素从页面中去除,其占用位置也将被删除。
十五、背景background的一些语法
background-image:url(背景图案.jpg,gif,bmp)
background-color:#FFFFFF(背景颜色)
background-color : transparent<--设定背景为透明色–>
background-repeat 改变背景图片的重复并排的设定
说明
repeat 背景图片并排
repeat-x 背景图片以X方向 并排
repeat-y 背景图片以Y方向 并排
no-repeat 背景图片不 以并排的方式处理
background-attachment是否固定图片位置
说明
scroll 拉动卷轴时,背景图片会跟着移动(缺省值)
fixed 拉动卷轴时,背景图片不会跟着移动
以长度定位background-position:x y
使用百分比定位background-position: x% y%
说明
x% 往右移
y% 往下移
backgroud-position: 0% 0%左边上方
backgroud-position: 0% 50%左边中间
backgroud-position: 50% 0%中间上方
backgroud-position: 50% 50%正中间
backgroud-position:100% 0%右边上方
backgroud-position: 0% 100%左边下方
backgroud-position: 100% 50%右边中间
backgroud-position: 50% 100%中间下方
backgroud-position: 100% 100%右边下方
以关键字定位
关键字说明
top 上 ( y = 0 )
center 中 ( x = 50, y = 50 )
bottom 下 ( y = 100 )
left 左 ( x= 0 )
Exp:
background-position:center
图片在指定背景中央X=50% Y=50%位置
background-position: 200px 30px
十六、注释的写法
在Html中:
<!-- footer -->
content
<!-- end footer -->
在CSS中:
/* ---------- header ----------------- */
Style
十七、CSS的命名规范
1. id的命名
(1)页面结构
容器: Container
页头:header
内容:content/container
页面主体:main
页尾:footer
导航:nav
侧栏:sidebar
栏目:column
页面外围控制整体布局宽度:wrapper
左右中:left right center
(2)导航
导航:nav
主导航:mainnav
子导航:subnav
顶导航:topnav
边导航:sidebar
左导航:leftsidebar
右导航:rightsidebar
菜单:menu
子菜单:submenu
标题: title
摘要: summary
(3)功能
标志:logo
广告:banner
登陆:login
登录条:loginbar
注册:regsiter
搜索:search
功能区:shop
标题:title
加入:joinus
状态:status
2. class的命名
(1)颜色:使用颜色的名称或者16进制代码,如
.red { color: red}
.f60 { color: #f60}
.ff8600 { color: #ff8600}
(2)字体大小,直接使用"font+字体大小"作为名称,如
.font12px { font-size: 12px}
.font9pt {font-size: 9pt}
(3)对齐样式,使用对齐目标的英文名称,如
.left { float:left}
.bottom { float:bottom}
(4)标题栏样式,使用"类别+功能"的方式命名,如
.barnews { }
.barproduct { }
注意事项::
u 一律小写
u 尽量用英文
u 不加中杠和下划线
u 2个组合的单词不用中杠和下划线可以将第二个单词的首字母大写(eg:mainContent);
u 尽量不缩写,除非一看就明白的单词.
3. 主要的站点css文件
主要的 master.css
模块 module.css
基本共用 base.css(root.css)
布局,版面 layout.css
主题 themes.css
专栏 columns.css
文字 font.css
表单 forms.css
补丁 mend.css
打印 print.css
十八、Padding影响宽度问题
如果一组要嵌套的标签之间需要些间距的话,那就留给位于里面的标签的margin属性吧,而不要去定义位
于外面的标签的padding
十九、完美的单象素外框线表格
table{border-collapse:collapse}
td{border:1px solid #000}
二十、如果文字过长,则将过长的部分变成省略号显示
<style=”width:120pxheight:50pxoverflow:hiddentext-overflow:ellipsiswhite-space:nowrap”>
二十一、并不是所有样式都要简写
当样式表前定义了如p{padding:1px2px 3px 4px}时,在后续工程中又增加了一个样式上补白5px,下补白
6px。我们并不一定要写成p.style1{padding:5px 6px 3px 4px}。可以写成p.style1{paddingtop:5pxpadding-right:6px},你可能会感觉这样写还不如原来那样好,但你想没想过,你的那种写法重复定义
了样式,另外你可以不必去找原来的下补白与左补白的值是多少!如果以后前一个样式P变了话,你定义的
p.style1的样式也要变。(此种方法对后期修改样式很重要)
二十二、几个常用到的CSS细节处理上的样式
1)中文字两端对齐:text-align:justifytext-justify:inter-ideograph
2)固定宽度汉字截断:overflow:hiddentext-overflow:ellipsiswhite-space:nowrap(不让其换行,不过只能
处理文字在一行上的截断,不能处理多行。)(IE5以上)FF不能,它只隐藏。
***万能强制换行:white-space:normalword-break:break-all
禁止换行:white-space:nowrap
强制换行:word-wrap:break-wordword-break: normal
.AutoNewline
{
/*word-break: break-all方法一必须*/
/*word-wrap:break-wordoverflow:hidden方法二*/
/*word-wrap:break-wordword-break: normal方法三 */
word-wrap:break-wordword-break:break-all}
.NoNewline
{
/*word-break: keep-all方法一必须*/
white-space:nowrap
}
3)固定宽度汉字(词)折行:table-layout:fixedword-break:break-all(IE5以上)FF不能。
4)<acronym title=”输入要提示的文字”style=”cursor:help”>文字</acronym>用鼠标放在前面的文
字上看效果。这个效果在国外的很多网站都可以看到,而国内的少又少。
5)图片设为半透明:.halfalpha { background-color:#000000filter:Alpha(Opacity=50)}在IE6及IE5测试通
过,FF未通过,这是因为这个样式是IE私有的东西;
6)FLASH透明:选中swf,打开原代码窗口,在</object>前输入<paramname=”wmode”
value=”transparent”>以上是针对IE的代码。
针对FIREFOX 给<embed>标签也增加类似参数wmode=”transparent”
7)在做网页时常用到把鼠标放在图片上会出现图片变亮的效果,可以用图片替换的技巧,也可以用如下的滤
镜:
.pictures img {
filter: alpha(opacity=45)}
.pictures a:hover img {
filter: alpha(opacity=90)}
8)层在浏览器中居中对齐问题
body { text-align: center }
#content { text-align: leftwidth: 700pxmargin: 0 auto }