一、CSS文件及
款式命名
1、CSS文件命名
标准
全局
款式:global.css;
框架布局:layout.css;
字体
款式:font.css;
链接
款式:link.css;
打印
款式:print.css;
2、CSS
款式命名
标准
本人
提议:用字母、_号工、-号、数字构成,必须以字母开头,不能为纯数字 。为了开发后
款式名治理容易,大家请用有
意思的单词或缩写组合来命名,让
共事一看就清楚这
款式大约是哪一块的,这样就
节俭了搜索
款式的
工夫,例如:
头部
款式用header,头部左边,
可以用header_left或header_l,还有假如是列
构造的
可以这样——box _1of3 (三列中的第一列),box_2of3 (三列中的第二列)、box _3of3 (三列中的第三列),其它的我就不逐个举例了,大家按以上
法则去命名就好 。
下面列出一些常用的命名单词容易大家
使用:(以后大家工作过程中
渐渐把自己积存的单词都共享出来,那大家的命就会更加统一了,就不会有一义多词的状况了 。)
容 器:container/box
头 部:header
主 导 航:mainNav
子 导 航:subNav
顶 导 航:topNav
网站
标记:logo
大 广 告:banner
页面中部:mainBody
底 部:footer
菜 单:menu
菜单内容:menuContent
子 菜 单:subMenu
子菜单内容:subMenuContent
搜 索:search
搜索
要害字:keyword
搜索
规模:range
标签文字:tagTitle
标签内容:tagContent
目前标签:tagCurrent/currentTag
标 题:title
内 容:content
列 表:list
目前位置:currentPath
侧 边 栏:sidebar
图 标:icon
注 释:note
登 录:login
注 册:register
列 定 义:column_1of3 (三列中的第一列)
column_2of3 (三列中的第二列)
column_3of3 (三列中的第三列)
二、id和class的
使用及区别
我们晓得在
款式表定义一个
款式的时候,
可以定义id也
可以定义class,例如:
ID
步骤:#test{color:#333333},在页面中调用<div>内容<div>
CLASS
步骤:.test{color:#333333},在页面中调用<div class="test">内容<div>
id一个页面只
可以
使用一次,class
可以
频繁
引用 。
我在页面中用了多个
雷同id在IE中显示也
畸形,id和class好象没什么区别,用多个
雷同id有什么影响吗?
页面存在多个
雷同的ID影响便是不能通过W3的校验 。
在页面显示上,目前的阅读器还都同意你犯这个
舛误,用多个
雷同ID“普通状况下”也能
畸形显示 。然而当你需求用JavaScript通过id来操纵这个div,那就会浮现
舛误 。
id是一个标签,用于
划分不同的
构造和内容,就象你的名字,假如一个屋子有2个人同名,就会浮现
混同;
class是一个
款式,
可以套在任何
构造和内容上,就象一件衣服;
概念上说便是不一样的:
id是先找到
构造/内容,再给它定义
款式;class是先定义好一种
款式,再套给多个
构造/内容 。
也便是说
提议大家在写XHML+CSS时假如是维一的
构造定位的就用id,不然就用class吧(这样让出非
构造定位的div块的id让程序员自己定义
使用)
web
标准
盼望大家用严格的习惯来写代码 。
三.
使用css缩写
使用缩写
可以协助削减你CSS文件的大小,更加容易阅读 。常用的css缩写的重要
规定:
色彩
16进制的
色彩值,假如每两位的值
雷同,
可以缩写一半,例如:
#000000
可以缩写为#000;#336699
可以缩写为#369;
盒尺寸
通常有下面四种书写
步骤:
property:value1;
示意全部边都是一个值value1;
property:value1 value2;
示意top和bottom的值是value1,right和left的值是value2
property:value1 value2 value3;
示意top的值是value1,right和left的值是value2,bottom的值是value3
property:value1 value2 value3 value4; 四个值
顺次
示意top,right,bottom,left
容易的记忆
步骤是顺时针,上右下左 。具体
利用在margin和padding的例子如下:
margin:1em 0 2em 0.5em;
边框(border)
边框的属性如下:
border-width:1px;
border-style:solid;
border-color:#000;
可以缩写为一句:border:1px solid #000;
语法是border:width style color;
背景(Backgrounds)
背景的属性如下:
background-color:#f00;
background-image:url(background.gif);
background-repeat:no-repeat;
background-attachment:fixed;
background-position:0 0;
可以缩写为一句:background:#f00 url(background.gif) no-repeat fixed 0 0;
语法是background:color image repeat attachment position;
你
可以省略其中一个或多个属性值,假如省略,该属性值将用阅读器默许值,默许值为:
color: transparent
image: none
repeat: repeat
attachment: scroll
position: 0% 0%
字体(fonts)
字体的属性如下:
font-style:italic;
font-variant:small-caps;
font-weight:bold;
font-size:1em;
line-height:140%;
font-family:"Lucida Grande",sans-serif;
可以缩写为一句:font:italic small-caps bold 1em/140% "Lucida Grande",sans-serif;
留神,假如你缩写字体定义,至少要定义font-size和font-family两个值 。
列表(lists)
取缔默许的圆点和序号
可以这样写list-style:none;
list的属性如下:
list-style-type:square;
list-style-position:inside;
list-style-image:url(image.gif);
可以缩写为一句:list-style:square inside url(image.gif);
四、明确定义单位,除非值为0
淡忘定义尺寸的单位是CSS新手
广泛的
舛误 。在HTML中你
可以只写width=100,然而在CSS中,你必须给一个精确的单位,
比方:width:100px width:100em 。惟独两个例外状况
可以不定义单位:行高和0值 。除此以外,
其余值都必须紧跟单位,
留神,不要在数值和单位中间加空格 。
五、
划分大小写
当在XHTML中
使用CSS,CSS里定义的元素名称是
划分大小写的 。为了幸免这种
舛误,我
提议全部的定义名称都采纳小写 。
class和id的值在HTML和XHTML中也是
划分大小写的,假如你
定然要大小写混合写,请
细心确认你在CSS的定义和XHTML里的标签是
统一的 。
六、
取缔class和id前的元素限定
当你写给一个元素定义class或者id,你
可以省略前面的元素限定,由于ID在一个页面里是唯一的,class
可以在页面中
频繁
使用 。你限定某个元素毫无
意思 。例如:
div#id1{}
可以写成#id1{}
这样
可以
节俭一些字节 。
七、默许值
通常padding和margin的默许值为0,background-color的默许值是transparent 。然而在不同的阅读器默许值可能不同 。假如怕有
摩擦,
可以在
款式表一开始就先定义全部元素的margin和padding值都为0,象这样:
* {
padding:0;
margin:0
}
或者是针对某元向来定义:
ul,li,div,span {
padding:0;
margin:0
}
八、CSS的优先级
行内
款式(inline style) > ID
取舍符 >
款式(class),伪类(pseudo-class)和属性(attribute)
取舍符 > 类别(type),伪对象(pseudo-element)
解释:
*内联
款式(inline style):元素的style属性,
比方 <div style="color:red;"></div> ,其中的color:red;便是行内
款式
*ID
取舍符:元素的id属性,
比方 <div></div>
可以用ID
取舍符#content
*伪类(pseudo-class):最常见的是锚(a)伪类,
比方a:link,a:visited.
*属性
取舍符(attribute selectors):
比方div[class=demo],含有class为demo的div元素
*类别
取舍器(type selector):HTML标签
取舍,
比方div .demo,div元素下含有class为demo的元素
*伪对象
取舍器(pseudo-element selector):
比方div:first-letter,div元素下的第一个单词 。
九、不需求
反复定义可继承的值
CSS中,子元素自动继承父元素的属性值,象
色彩、字体等,已经在父元素中定义过的,在子元素中
可以直接继承,不需求
反复定义,除非是为了更变目前元素
款式不
使用父元素的属性值,然而要
留神,阅读器可能用一些默许值
遮蔽你的定义 。
十.多重CSS
款式定义,属性追加
反复最终优先
准则
一个标签
可以同时定义多个class,也
可以是同一个class中
反复定义属性 。例如:
我们先定义两个
款式
.one{width:200px;background:url(1.jpg) no-repeat left top;}
.two{border:10px solid #000; background:url(2.jpg) no-repeat left top;}
在页面代码中,我们
可以这样调用:
<div class="one" two></div>
这样最终的显示
动机是这个div
款式是什么呢??
反复的是以哪一个为准呢??
<div class="one" two></div>
利用到的
款式如下:
width:200px;
border:10px solid #000;
background:url(2.jpg) no-repeat left top;
由于,当
利用两个或多个
款式时,阅读器所
利用的
款式依据是属性追加
反复最终优先
准则
便是说两个或多个或
反复的
款式名定义,阅读器所
利用的
款式是按先后顺序的,假如定义了
反复的属性值,以最终定义的为准,假如
利用了两个或多个
款式名,里面不
反复定义的属性值就追外加去,
反复的属性值就以最终一个为准 。这里要
留神的是,
款式的先后不是依据页面上
利用的名字顺序,而是
款式表里的
款式顺序 。
十一、
使用子
取舍器(descendant selectors)
使用子
取舍器是影响他们效率的缘由之一 。子
取舍器
可以协助你节约大量的class定义 。我们来看下面这段代码:
<div>
<ul>
<li class="subnavitem"> <a href=http://duote.com/# class="subnavitem">Item 1</a></li>>
<li class="subnavitemselected"> <a href="http://duote.com/#" class="subnavitemselected"> Item 1</a> </li>
<li class="subnavitem"> <a href="http://duote.com/#" class="subnavitem"> Item 1</a> </li>
</ul>
</div>
这段代码的CSS定义是:
div#subnav ul { }
div#subnav ul li.subnavitem { }
div#subnav ul li.subnavitem a.subnavitem { }
div#subnav ul li.subnavitemselected { }
div#subnav ul li.subnavitemselected a.subnavitemselected { }
你
可以用下面的
步骤
代替上面的代码
<ul id=”subnav”>
<li> <a href="http://duote.com/#>" Item 1</a> </li>
<li class="sel"> <a href="http:/duote.com/#>" Item 1</a> </li>
<li> <a href="http://duote.com/#>" Item 1</a> </li>
</ul>
款式定义是:
#subnav { }
#subnav li { }
#subnav a { }
#subnav .sel { }
#subnav .sel a { }
用子
取舍器
可以使你的代码和CSS更加简洁、更加容易阅读 。
假如一个容器里有多个同样的元素,并且这些元素
款式都不一样,请幸免用这个
模式,建以采纳不同的class如:
<ul class=”one”><li></li></ul>
<ul class=”tow”><li></li></ul>
十二、不需求给背景图片路径加引号
为了
节俭字节,我
提议不要给背景图片路径加引号,由于引号不是必须的 。例如:
background-image:url(“images
margin:0 auto;
}
然而IE5/Win不能正确显示这个定义,我们采纳一个十分有用的技巧来解决:用text-align属性 。就象这样:
body {
text-align:center;
}
#wrap {
width:760px;
margin:0 auto;
text-align:left;
}
第一个body的text-align:center;
规定定义IE5/Win中body的全部元素居中(
其余阅读器只不过将文字居中) ,第二个text-align:left;是将#warp中的文字居左 。
十三、导入(Import)和
潜藏CSS
由于老版本阅读器不
支撑CSS,一个通常的做法是
使用@import技巧来把CSS
潜藏起来 。例如:
@import url(main.css);
然而,这个
步骤对IE4不起作用,这让我很是头疼了一阵子 。后来我用这样的写法:
@import main.css;
这样就
可以在IE4中也
潜藏CSS了,呵呵,还
节俭了5个字节呢 。想了解@import语法的
详尽
注明,
可以看这里《centricle’s css filter chart》
十四、CSS hack
有些时候,你需求对IE阅读器的bug定义一些特殊的
规定,这里有太多的CSS技巧(hacks),我只
使用其中的两种
步骤,
无论微软在马上公布的IE7 beta版里是不是更好的
支撑CSS,这两种
步骤都是最安全的 。
1.
诠释的
步骤
(a)在IE中
潜藏一个CSS定义,你
可以
使用子
取舍器(child selector):
html>body p {
}
(b)下面这个写法惟独IE阅读器
可以
了解(对
其余阅读器都
潜藏)
* html p {
}
(c)还有些时候,你
盼望IE/Win有效而IE/Mac
潜藏,你
可以
使用反斜线技巧:
* html p {
declarations
}
(d)下面这个写法惟独IE7阅读器
可以
了解(对
其余阅读器都
潜藏)
*+ html p {
}
2.条件
诠释(conditional comments)的
步骤
另外一种
步骤,我认为比CSS Hacks更加经得起考验便是采纳微软的私有属性条件
诠释(conditional comments) 。用这个
步骤你
可以给IE
径自定义一些
款式,而不影响主
款式表的定义 。就象这样:
<!--[if IE]>
<link rel=stylesheet/css href="http://www.duote.com/style/ie.css" />
<![endif]-->
还有更多的CSS hack大家
可以通过网上找找,然而有众多hack都是不
相符w3c
标准的,本人依据以上的hack写了一个能
划分IE6、IE7、FF的
款式,并且
可以
相符w3c
标准,代码如下:
.classname {width:90px!important;width:100px;}
*+html .classname {width:95px!important;}
这样写后在IE6下宽是100px,IE7下是95px,火狐下是90px 。
十五、调试技巧:层有多大?
当调试CSS
产生
舛误,你就要象排版工人,逐行
综合CSS代码 。我通常在出问题的层上定义一个背景
色彩,这样就能很显而易见看到层占领多大空间 。有些人
提议用border,普通状况也是
可以的,但问题是,有时候border 会添加元素的尺寸,border-top和boeder-bottom会
毁坏纵向margin的值,所以
使用background更加安全些 。
另外一个
时常出问题的属性是outline 。outline看起来象boeder,但不会影响元素的尺寸或者位置 。惟独少数阅读器
支撑outline属性,我所晓得的惟独Safari、OmniWeb、和Opera 。
十六、CSS代码书写
款式
在写CSS代码的时候,关于缩进、断行、空格,每个人有每个人的书写习惯 。在
通过不停
实际后,我决定采纳下面这样的书写
款式:
.classname {
width:100px;
}
当
使用联合定义时,我通常将每个
取舍器
径自写一行,这样容易在CSS文件中找到它们 。在最终一个
取舍器和大括号{中间加一个空格,每个定义也
径自写一行,分号直接在属性值后,不要加空格 。
我习惯在每个属性值后面都加分号,
固然
规定上同意最终一个属性值后面
可以不写分号,然而假如你要加新
款式时容易
淡忘补上分号而产生
舛误,所以还是都加
比较好 。
最终,关闭的大括号}
径自写一行 。空格和换行有助与阅读 。