社区应用 最新帖子 精华区 社区服务 会员列表 统计排行 社区论坛任务 迷你宠物
  • 11604阅读
  • 12回复

[C/C++]〓〓 DIV+CSS 学习(入门)教程 〓〓(内容更新)

级别: 店掌柜
发帖
5692
铜板
103378
人品值
1520
贡献值
26
交易币
0
好评度
5373
信誉值
0
金币
0
所在楼道

前言: VZ 7(6?W  
$++O@C5  
今后将陆续转载部分精品学习教程和发一些自己学习中的经验在这里 H_aG\  
{r5OtYmpR  
希望和大家一起学习 一起进步 )dJx82" l  
cVr+Wp7K#|  
不论什么样 web2.0的标准已经到来,越来越多的网站开始基于div+css的网页设计当中。 bUYjmb2g)  
<:8Ew  
希望提供这些内容给需要的人 YJ~mcaw  
Z B!~@Vf  
U9 mK^  
------------------------------------------------ sN#ju5  
$>+g)  
常用CSS缩写语法总结 kZi/2UA5Z  
使用缩写可以帮助减少你CSS文件的大小,更加容易阅读。css缩写的主要规则如下: 6mgLeeY  
mGkQx -|  
颜色 (<e<Q~(  
16进制的色彩值,如果每两位的值相同,可以缩写一半,例如: MY}K.^ 4^  
#000000可以缩写为#000;#336699可以缩写为#369; jCIY(/  
!E)|[:$XT  
盒尺寸 f=S2O_Ee  
通常有下面四种书写方法: Imq-5To#  
T{yJL<  
property:value1; 表示所有边都是一个值value1; VC% .u.< F  
property:value1 value2; 表示top和bottom的值是value1,right和left的值是value2 $3%+N|L  
property:value1 value2 value3; 表示top的值是value1,right和left的值是value2,bottom的值是value3 hMV>5Y[s  
property:value1 value2 value3 value4; 四个值依次表示top,right,bottom,left OkCAvRg  
方便的记忆方法是顺时针,上右下左。具体应用在margin和padding的例子如下: | :id/  
margin:1em 0 2em 0.5em; )%lPKp4]  
{2i8]Sp1d/  
边框(border) 33&\E- Q>  
边框的属性如下: V\l@_%D[(v  
`82Dm!V  
border-width:1px;  Wu8^Z Z{  
border-style:solid; ]e+&Pxw]e  
border-color:#000; XGjFb4Tw7  
可以缩写为一句:border:1px solid #000; {OOn7=  
$ \o)-3  
语法是border:width style color; ~03MH'  
F!*GrQms  
背景(Backgrounds) ?zbWz=nq  
背景的属性如下: wkV'']= Xg  
BL"7_phM,  
background-color:#f00; Ed2A\S6tl  
background-image:url(background.gif); uv^x  
background-repeat:no-repeat; < $otBC/%  
background-attachment:fixed; |k,-]c;6  
background-position:0 0; & Y2xO  
可以缩写为一句:background:#f00 url(background.gif) no-repeat fixed 0 0; Bvh{|tP4  
1i'y0]f  
语法是background:color image repeat attachment position; 1uB$@a\  
k,f/9e+#  
你可以省略其中一个或多个属性值,如果省略,该属性值将用浏览器默认值,默认值为: nr,Z0  
ED>a'y$f  
color: transparent y*v|q=  
image: none >7S@3,C3ke  
repeat: repeat 5K)_w:U X  
attachment: scroll /H3w7QU  
position: 0% 0% m4Ue)  
字体(fonts) Ndgx@LTQQ  
字体的属性如下: 9.il1mAKg  
 _+(@?  
font-style:italic; ,|.}6\zl*{  
font-variant:small-caps; j-DWz>x  
font-weight:bold; t V>qV\>  
font-size:1em; N]6t)Zv  
line-height:140%; e0otr_)3F  
font-family:"Lucida Grande",sans-serif; %~P T7"4  
可以缩写为一句:font:italic small-caps bold 1em/140% "Lucida Grande",sans-serif; %H,s~IU  
\j3dB tc  
注意,如果你缩写字体定义,至少要定义font-size和font-family两个值。 ?,8+1"|$A]  
XrWWV2[  
列表(lists) rPqM&&+  
取消默认的圆点和序号可以这样写list-style:none;, a(D=ZKbVU  
$$"G1<EZ  
list的属性如下: ~131|e`C  
p8?v o ?^  
list-style-type:square; >}W[>WReI  
list-style-position:inside; ]^>:)q  
list-style-image:url(image.gif); =  
可以缩写为一句:list-style:square inside url(image.gif);
评价一下你浏览此帖子的感受

精彩

感动

搞笑

开心

愤怒

无聊

灌水

简单生活
执著追求
别笑我浅溥,天真的以为用一腔真诚就能感动这个冷漠的世界。
也别说我幼稚,竟想用不长的人生去诠释繁杂的红尘。
然而除了真诚,我还能给你什么,的确我真的一无所有!

级别: 店掌柜
发帖
5692
铜板
103378
人品值
1520
贡献值
26
交易币
0
好评度
5373
信誉值
0
金币
0
所在楼道

只看该作者 1 发表于: 2006-07-26
初学CSS和标准建站的一些CSS常用技巧 /*无所不能的CSS的*通配选择符*/ ~id:Rh>o  
x;\/Xj ;  
* { F"O\uo:3  
eF9GhwE=  
margin:0; VuH ->  
padding:0;} IF\ @uo`  
2lOUNxQ$  
/*此定义解释:margin:0;padding:0;在CSS最上面先用 * 一次性统一制定,可以避开CSS的"盒模型"考虑问猓?迸龅叫枰?乇? =WBfaxL}  
指定margin或padding值的时候在分别另外指定,后面的值将覆盖前面的值。*/ TsGx2[  
|D%mWQng  
/kg#i&bP~  
u *rP 8GuS  
'[%#70*  
P)J-'2{  
/*CSS中容易被忽视的Outlines 轮廓属性*/ 't0M+_J  
问题:为什么加了<a>标签的<img>全部自动加上了蓝色的边缘? fwV2b<[  
因为每个默认<img>的boarder值不为0,可以将boarder设置为0,可以解决问题。 79exZ7|  
:zLf~ W  
img{ T<? kH  
boarder:0; ^\?Rh(pu  
display:block; ^2+ Vt=*  
}/*此定义解释:boarder:0;可以避免带链接的图片边缘出现蓝色边框。display:block;将图片以块级元素显示*/ D&D6!jz  
"QiR  
/*其他还有非常容易<form>,<select>,<input>,影响布局的标签,都可以先将其margin和padding都预先设置为0*/ PPIO<K 3`  
$?bD55  
L \E>5G;  
form{margin:0;padding:0;} &tvp)B?cWk  
select{margin:0;padding:0;} ,w H~.LHi  
input{margin:0;padding:0;} F P|cA^$<  
*4}NLUVX  
VJ&<6  
,m5i(WL  
a%`%("g!  
}$'_%,  
E5M/XW\E6  
body{ !]82$  
margin:0px; C&MqH.K  
font: normal 12px "宋体", Verdana, Arial, Helvetica,sans-serif; dS4zOz"  
text-align:center; )H{1 Xjh-  
color:#000; z[v4(pO 6  
line-height:140%;} ^MF 2Q+  
L\:m)g,F.  
Ez5t)l-  
>(S)aug$1  
#top_box D5snaGss9a  
{width:760px;height:63px; '5De1K.\`  
margin:auto; ,6X;YY  
padding-top:10px; h-?yed*?  
text-align:left; 7Y(Dg`8G  
} \&;y:4&l8  
xd ^Pkf  
a:link,a:visited,a:active{color:#000; text-decoration:none;} ng!cK<p  
a:hover{color:#ff0000; text-decoration:underline;} i\ X3t5  
+KIz#uqF8Z  
/*此定义解释:将所有A标签预先指定样式,也可用在CSS最开始一段代码,统一定义*/ 85q/|9D  
YRX^fZ-b  
n+ebi>}P  
^Z?m)qxvB  
/*有关CSS的其他常见问题及解决办法和分析:*/ C|TQf8  
>Wt@O\k  
/*关于CSS容器与CSS元素的适应问题*/ m1Ya  
/*例如有时候我们要在首页动态打印一列十条文章,要放在一个CSS容器DIV内,若每行文字太多,元素很容易破坏容器而使整个布局变坏 `?(J(H  
下面是解决的办法*/ fJc(  
O& Sk}^  
#nowrap{table-layout:fixed} $jE<n/8  
PR:B6 F8  
<div id="nowrap">文字不折行</div> A+* lV*@0  
Mh-"B([Z  
等同于<td nowrap>文字不折行<td> 8xgBNQdPT  
jc Mn   
o?>0WSLlm  
CSS指定宽度文字自动换行显示: XNJZ~Mowb  
VPYLDg.'  
#wrap{word-break:break-all;width:200px;} aO&{.DO2  
<div id="wrap">每200像素宽度文字就自动折行</div> A_wf_.l4h  
Yz_}*  
/*CSS常用缩写规范*/ KYm8|]'g  
s0f+AS|}  
/*缩写示例: )__sw  
1.*/ -6kX?sNl)X  
D5P-$1KPt  
.pop_font{ Kgr<OL}VJ  
font: bold 11px "宋体", Verdana, Arial, Helvetica,sans-serif;} *pa hZiO  
:p/=KI_  
/*缩写示例: )LFbz#;Y  
2.*/ I!*P' {lh  
ue@/o,C>  
.pop_td{ 9S@x  
border-right: 1px solid #C1DAD7;} C78g|n{  
qm!oJL  
V=8db% ^  
/*缩写示例: (c0L H  
3.*/ +?U[362>  
%"Um8`]FVg  
P(k*SB|D  
.pic_background{ Twa(RjB<  
background: transparent url(/images/bullet1.gif) no-repeat 20px 20px; Q ^2dZXk~  
padding:2px 0; '2lzMc>wvP  
margin:2px 0 2px 0;} 0<!9D):Bb  
q& -mbWBj  
PljPhAce  
<|_>r`@%l  
+a.2\Qt2A  
|JIlp"[  
/*关于DIV布局中的UL,LI中带ID的CSS属性定义方式:*/ K-TsSW$}  
-@(LN%7!C  
<div id="main"> SED52$zA  
<ul id="ok1"> Wn@oG@}~  
<li id="li1">文字1</li> 5WHz_'c  
<li>文字2</li> zU&Iy_Ke.  
</ul> qSr]d`7@  
<ul> giNXX jl  
<li>文字3</li> 6I"KomJ9  
</ul> h#r~2\q4ei  
</div> / e>%yq<9B  
f )T\  
>o1dc*  
/*对 "文字1"定义CSS样式: #17 &rizl  
:VlA2Ih&q  
以下都是正确的指定样式:*/ q"2APvsvp  
#li1 {/*指定样式代码*/} 1cOR?=G~  
#main li#li1 {/*指定样式代码*/} Pq [_(Nt  
#main #ok1 #li1 {/*指定样式代码*/} DfAF-Yhut  
#main ul#ok1 li#li1{/*指定样式代码*/} i6_}  
Ct)58f2  
/*以下都是错误的CSS指定"文字1“的样式:*/ "D.<~!  
Sz Mh  
#li{} ]Wkgpfd56  
#main ul li1{} RQ8d1US  
li1{} Nq`;\E.M  
qG;tD>jy  
/*end*/

简单生活
执著追求
别笑我浅溥,天真的以为用一腔真诚就能感动这个冷漠的世界。
也别说我幼稚,竟想用不长的人生去诠释繁杂的红尘。
然而除了真诚,我还能给你什么,的确我真的一无所有!

级别: 店掌柜
发帖
5692
铜板
103378
人品值
1520
贡献值
26
交易币
0
好评度
5373
信誉值
0
金币
0
所在楼道

只看该作者 2 发表于: 2006-07-26
CSS的十八般技巧 &233QRYM  
2JK '!Ry)  
一.使用css缩写 s_y8+BJaV  
使用缩写可以帮助减少你CSS文件的大小,更加容易阅读。css缩写的主要规则请参看《常用css缩写语法总结》,这里就不展开描述。 Ds(Z.  
二.明确定义单位,除非值为0 /.e7#-+?  
忘记定义尺寸的单位是CSS新手普遍的错误。在HTML中你可以只写width="100",但是在CSS中,你必须给一个准确的单位,比如:width:100px width:100em。只有两个例外情况可以不定义单位:行高和0值。除此以外,其他值都必须紧跟单位,注意,不要在数值和单位之间加空格。 [+D]!&P  
三.区分大小写 "YI,  
当在XHTML中使用CSS,CSS里定义的元素名称是区分大小写的。为了避免这种错误,我建议所有的定义名称都采用小写。 W_M#Gi/ AL  
class和id的值在HTML和XHTML中也是区分大小写的,如果你一定要大小写混合写,请仔细确认你在CSS的定义和XHTML里的标签是一致的。 X\;:aRDS  
四.取消class和id前的元素限定 Im~DK  
当你写给一个元素定义class或者id,你可以省略前面的元素限定,因为ID在一个页面里是唯一的,而clas s可以在页面中多次使用。你限定某个元素毫无意义。例如: Z4/D38_  
div#content { /* declarations */ } .@)vJtH)  
fieldset.details { /* declarations */ } L/rf5||@  
可以写成 P{A})t7  
#content { /* declarations */ } :L@ ;.s  
.details { /* declarations */ } ~o_JZ:  
这样可以节省一些字节。 >Gpq{Ph[  
五.默认值 4ekwmw(ox  
通常padding的默认值为0,background-color的默认值是transparent。但是在不同的浏览器默认值可能不同。如果怕有冲突,可以在样式表一开始就先定义所有元素的margin和padding值都为0,象这样: Cl&mz1Y;]1  
* { 4E.9CjN1>  
margin:0; ^(:~8 h  
padding:0; E:8*o7  
} BmV `<Q,  
六.不需要重复定义可继承的值 $(D>v!dp  
CSS中,子元素自动继承父元素的属性值,象颜色、字体等,已经在父元素中定义过的,在子元素中可以直接继承,不需要重复定义。但是要注意,浏览器可能用一些默认值覆盖你的定义。 0~U%csPHt  
七.最近优先原则 =?C <@  
如果对同一个元素的定义有多种,以最接近(最小一级)的定义为最优先,例如有这么一段代码 k( 0;>)<i  
Update: Lorem ipsum dolor set B{Vc-qJ  
在CSS文件中,你已经定义了元素p,又定义了一个class"update" |^Y"*Y4*h  
p { )$TN%hV!  
margin:1em 0; \Vx^u}3O  
font-size:1em; FQO=}0Hl  
color:#333; Sa<(F[p`  
} =.8n K y  
.update { gra6&&^"  
font-weight:bold; ;j1 SSHZ  
color:#600; ;av!fK  
} Dc0=gq0  
这两个定义中,class="update"将被使用,因为class比p更近。 !+3&%vQ)  
八.多重class定义 U3&GRY|##  
一个标签可以同时定义多个class。例如:我们先定义两个样式,第一个样式背景为#666;第二个样式有10 px的边框。 3;L$&X2  
.one{width:200px;background:#666;} d\>XfS  
.two{border:10px solid #F00;} -& (iU#W  
在页面代码中,我们可以这样调用 sf2%WPK  
这样最终的显示效果是这个div既有#666的背景,也有10px的边框。是的,这样做是可以的,你可以尝试一下。 e;XRH<LhAU  
九.使用子选择器(descendant selectors) m OUO)[6y  
CSS初学者不知道使用子选择器是影响他们效率的原因之一。子选择器可以帮助你节约大量的class定义。我们来看下面这段代码: WOj}+?/3 R  
Item 1 } +Sp7F1q  
Item 1 \ Ki3ls  
Item 1 Ac U@H0  
这段代码的CSS定义是: AwG0E `SU  
div#subnav ul { /* Some styling */ } )dfhy  
div#subnav ul li.subnavitem { /* Some styling */ } t[2b~peNI  
div#subnav ul li.subnavitem a.subnavitem { /* Some styling */ } `l]Lvk8O  
div#subnav ul li.subnavitemselected { /* Some styling */ } 0qNk.1pv  
div#subnav ul li.subnavitemselected a.subnavitemselected { /* Some styling */ } M#4;y,n<k  
你可以用下面的方法替代上面的代码 w? _8OJ  
Item 1 w =F9>  
Item 1 \r:*`Z*y  
Item 1 GkU_01C  
样式定义是: !$l<'K$  
#subnav { /* Some styling */ } Brxnl,%\  
#subnav li { /* Some styling */ } 5!A:xV]6]  
#subnav a { /* Some styling */ } k9*UBx  
#subnav .sel { /* Some styling */ } /#vt \I<x  
#subnav .sel a { /* Some styling */ } nmiJ2edx  
用子选择器可以使你的代码和CSS更加简洁、更加容易阅读。 ;MGm,F,o  
十.不需要给背景图片路径加引号 H_f8/H  
为了节省字节,我建议不要给背景图片路径加引号,因为引号不是必须的。例如: ?S& yF  
background:url("images/***.gif") #333; -KC@M  
可以写为 By6O@ .\V  
background:url(images/***.gif) #333; 1P"7.{  
如果你加了引号,反而会引起一些浏览器的错误。 "=DQ {(L  
十一.组选择器(Group selectors) WwsNAJ  
当一些元素类型、class或者id都有共同的一些属性,你就可以使用组选择器来避免多次的重复定义。这可以节省不少字节。 1f+A_k/@  
例如:定义所有标题的字体、颜色和margin,你可以这样写: ,X3D< wl  
h1,h2,h3,h4,h5,h6 { 3A ^AEO  
font-family:"Lucida Grande",Lucida,Arial,Helvetica,sans-serif; kkZ}&OXS;  
color:#333; L@O>;zp;  
margin:1em 0; 5nib<B%<V  
} BC!) g+8  
如果在使用时,有个别元素需要定义独立样式,你可以再加上新的定义,可以覆盖老的定义,例如: C _he=SV  
h1 { font-size:2em; } =SmU ;t>t/  
h2 { font-size:1.6em; } S}rEQGGR{  
十二.用正确的顺序指定链接的样式 ahg P"Qz  
当你用CSS来定义链接的多个状态样式时,要注意它们书写的顺序,正确的顺序是::link :visited :hover :active。抽取第一个字母是"LVHA",你可以记忆成"LoVe HAte"(喜欢讨厌)。 <k8WnA ~Fl  
如果你的用户需要用键盘来控制,需要知道当前链接的焦点,你还可以定义:focus属性。:focus属性的效果也取决与你书写的位置,如果你希望聚焦元素显示:hover效果,你就把:focus写在:hover前面;如果你希望聚焦效果替代:hover效果,你就把:focus放在:hover后面。 T+T)~!{%  
十三.清除浮动 F1BvDplQ>G  
一个非常常见的CSS问题,定位使用浮动的时候,下面的层被浮动的层所覆盖,或者层里嵌套的子层超出了外层的范围。 NpGi3>5  
通常的解决办法是在浮动层后面添加一个额外元素,例如一个div或者一个br,并且定义它的样式为clear: both。这个办法有一点牵强,幸运的是还有一个好办法可以解决 8B-PsS|'  
十四.横向居中(centering) EE]xZz>o  
这是一个简单的技巧,但是值得再说一遍,因为我看见太多的新手问题都是问这个:CSS如何横向居中?你需要定义元素的宽,并且定义横向的margin,如果你的布局包含在一个层(容器)中,就象这样: 1/mBp+D  
你可以这样定义使它横向居中: >[wxZ5))  
#wrap { EoutB Vm  
width:760px; /* 修改为你的层的宽度 */ I*%3E.Z@g  
margin:0 auto; 7ucm1   
} KKk~vwW  
但是IE5/Win不能正确显示这个定义,我们采用一个非常有用的技巧来解决:用text-align属性。就象这样: 9~=zD9,|iA  
body { %0y-f  
text-align:center; Lbo3fwW  
} 07>m*1G  
#wrap { iC hIW/H  
width:760px; /* 修改为你的层的宽度 */ l4$ sku-  
margin:0 auto; Eg1TF oIWl  
text-align:left; ??e|ec2%  
} (&79}IEd  
第一个body的text-align:center; 规则定义IE5/Win中body的所有元素居中(其他浏览器只是将文字居中) ,第二个text-align:left;是将#warp中的文字居左。 @BLB.=  
十五.导入(Import)和隐藏CSS 4r_*: $g  
因为老版本浏览器不支持CSS,一个通常的做法是使用@import技巧来把CSS隐藏起来。例如: '2Zs15)V  
@import url("main.css"); nW]CA~  
然而,这个方法对IE4不起作用,这让我很是头疼了一阵子。后来我用这样的写法: 8Ys)qx>7'  
@import "main.css"; }.D18bE(  
这样就可以在IE4中也隐藏CSS了,呵呵,还节省了5个字节呢。 V?yQm4  
十六.针对IE的优化 MPnMLUB$\  
有些时候,你需要对IE浏览器的bug定义一些特别的规则,这里有太多的CSS技巧(hacks),我只使用其中的两种方法,不管微软在即将发布的IE7 beta版里是否更好的支持CSS,这两种方法都是最安全的。 *PlKl_nP6  
1.注释的方法 :j~4mb?$  
(a)在IE中隐藏一个CSS定义,你可以使用子选择器(child selector): ;g8v7>p  
html>body p { :4[>]&:u3  
/* 定义内容 */ {.oz^~zs]g  
} u= dj3q  
(b)下面这个写法只有IE浏览器可以理解(对其他浏览器都隐藏) ^7>~y(  
* html p { 5q@s6_"{  
/* declarations */ eb}XooX  
} q'7.lrKwa>  
(c)还有些时候,你希望IE/Win有效而IE/Mac隐藏,你可以使用"反斜线"技巧: fcp_<2KH  
/* \*/ OU` !c[O  
* html p { E8PwA.  
declarations *MfH\X379  
} mEYfsO  
/* */ ?4wl  
2.条件注释(conditional comments)的方法 `0%;Gz%}  
另外一种方法,我认为比CSS Hacks更加经得起考验就是采用微软的私有属性条件注释(conditional comments)。用这个方法你可以给IE单独定义一些样式,而不影响主样式表的定义。就象这样: 7./WS,49  
十七.调试技巧:层有多大? I/upiqy  
当调试CSS发生错误,你就要象排版工人,逐行分析CSS代码。我通常在出问题的层上定义一个背景颜色,这样就能很明显看到层占据多大空间。有些人建议用border,一般情况也是可以的,但问题是,有时候border 会增加元素的尺寸,border-top和boeder-bottom会破坏纵向margin的值,所以使用background更加安全些。 k;<@ 2C  
另外一个经常出问题的属性是outline。outline看起来象boeder,但不会影响元素的尺寸或者位置。只有少数浏览器支持outline属性,我所知道的只有Safari、OmniWeb、和Opera。 ,V j&  
十八.CSS代码书写样式 :55a9d1bL  
在写CSS代码的时候,对于缩进、断行、空格,每个人有每个人的书写习惯。在经过不断实践后,我决定采用下面这样的书写样式: S=S/]]e  
selector1, !W,LG$=/  
selector2 { -wH0g^Ed  
property:value; R#Yj%$E1  
} E4\HI+  
当使用联合定义时,我通常将每个选择器单独写一行,这样方便在CSS文件中找到它们。在最后一个选择器和大括号{之间加一个空格,每个定义也单独写一行,分号直接在属性值后,不要加空格。 lGK7XAx,  
我习惯在每个属性值后面都加分号,虽然规则上允许最后一个属性值后面可以不写分号,但是如果你要加新样式时容易忘记补上分号而产生错误,所以还是都加比较好。  7Oe$Ou  
最后,关闭的大括号}单独写一行。 z7BFkZ6+  
空格和换行有助与阅读。

简单生活
执著追求
别笑我浅溥,天真的以为用一腔真诚就能感动这个冷漠的世界。
也别说我幼稚,竟想用不长的人生去诠释繁杂的红尘。
然而除了真诚,我还能给你什么,的确我真的一无所有!

级别: 店掌柜
发帖
5692
铜板
103378
人品值
1520
贡献值
26
交易币
0
好评度
5373
信誉值
0
金币
0
所在楼道

只看该作者 3 发表于: 2006-07-26
定义标题的最好方法 r/':^Ex  
n>B ,O  
一个文档标题,最好的定义方法是什么?要回答这个问题,先设想我们要在一个页面上定义文章的标题,通常我们有三个方法来实现这个简单目的: ?Qd`Vlp7  
d14@G4#Bd  
)@U~Li/+  
方法一: 有意义吗? HLthVc w  
<span class="heading">文章标题</span> x]hG2on!  
虽然在某些情况下<span>会是一个方便的标签,但它并不能表达出标题的完整含义。采用这个方法的一个好处是,我们可以对它附加一个CSS规则,分配其一个heading class,使其文字象标题一样显示。 0n4(Rj|}2  
.heading { =n=!s{A:t  
font-size: 24px; b^<7a&  
font-weight: bold; r9 1i :  
color: blue; sqF.,A,  
}
CD#U`jf  
F@ pf._c  
K&{ _s  
ok,现在所有的标题都用heading class标记成了大号的粗体字体,并且为蓝色。太棒了!但是这样做对吗?如果有人用一个不支持CSS的浏览器来观看,会怎样呢? oPBKPGD  
举个例子,如果我们设置的这个外部样式表的规则不被老版本的浏览器支持,会怎样?又或者有视觉障碍的人用屏幕阅读器来阅读这个页面,又会怎样?一个访问者通过这些途径所看到(或听到)的应该和这个页面上正常的文本没有任何区别。 =B+dhZ+#S$  
Z= -fL  
p|qLr9\A  
尽管class="heading"为这个标签增加了一点意义,但<span>仍然只是一个普通的标签,可以被大多数浏览器的缺省样式所修改掉。 UWqiA`,  
7)O+s/.P)  
p]~PyzG!  
搜索引擎检索这个页面时会略过<span>标签,就好象它不存在一样,不会对其可能包含的关键字给于一点额外的重视。在后面我们会更多的谈到搜索引擎和标题的关系。 Hsov0  
(6H 7?nv  
=],c$)  
最后,由于<span>标签是一个内嵌元素,我们可能需要把它嵌套在一个额外的块级元素中,比如<p>标签或<div>标签,为的是使它能够形成单独的行,这会进一步被非必要的代码弄乱你的标签。而这些额外增加的标签却是必须的,这样才能使不支持CSS的浏览器显示出没有差别的文本。 Z s| *+[  
(I;81h`1G  
QCDica `+*  
方法二:<p>和<b>组合 * #z@b  
<p><b>文章标题</b></p> xrY >Or  
使用一个段落标签,将会给我们带来块级的显示,<b>会把文本变成粗体。但是用这个方法标记一个重要的标题时,我们面对的是同样无意义的结果。 Q;y4yJ$wI  
不象方法A,<b>标签能在可视化的浏览器中把文字显示成粗体——甚至在不支持CSS的浏览器中。但是和<span>标签一样,搜索引擎也不会因为有一些东西在段落中被加粗了而给予更高的优先。 <o|k'Y(-  
"5$p=|  
L`O7-'`  
难以设计样式 #/9Y}2G|]  
用普通的<p>和<b>的组合,也带来了另一个缺憾——无法把这个标题设计成不同于其他段落的样式。我们可能想用一个特别的样式来突出标题,来使页面内容更清晰更具结构,但是用这个方法只能使其显示成粗体。 ? YIe<  
bx6=LK  
6W]C`  
方法三:样式加实质 v^t oe  
<h1>文章标题</h1> RxV " ,  
恩,多么好的标题定义。大多数的网页设计者对它都很熟悉。其实适当的使用它们,<Hn> 就能为页面内容提供灵活的、可索引的、以及可样式化的结构。 w .M  
这也是聪明的定义方法,你会发现它很简单。不再需要额外的标签,你可以说,这仅仅比另外两个方法节省了一点点的字节,可以忽略不计,但节省一点是一点。 #@V<{/;49  
<h1>一直到<h6>,代表了标题的六个级别,从最重要的(<h1>)到最次要的(<h6>)。他们本身就是块级的,不需要增加其它元素来使其单独成行。简单,有效——就是好工具。 .2rpQa/h  
;sUvY*Bcm  
yO\bVu5V  
轻松定制样式 #jxPh!%9  
因为我们使用<h1>标签是唯一的,而<b>或<p>标签更适合使用在整个页面,所以我们可以用各种各样的CSS方法来样式化。 p}I\H ^"8+  
更重要的是,尽管完全不用样式,一个标题标签也能明显的表示出一个标题!可视化的浏览器把 <h1>显示成更大的粗体。一个非样式化的页面将以被期望的那样显示文档结构,用适当的标题标签来传达意思。 D'D IC  
*>EV4Hl  
 L`Ys`7  
屏幕阅读器、PDA、手机、以及可视化的和非可视化的浏览器都会明白,碰到一个标题标签时该做的事情,正确的处理,比页面上的普通文本更重视的来对待。而使用<span>标签,那些不支持CSS的浏览器就不会特别的对待它。  Hi\z-P-  
c":2<:D&  
{pre|r\  
讨厌的默认样式 (B@\Dw8^  
以往,由于浏览器默认的缺省值非常的丑陋,设计者们也许会避免完全的使用标题标签。或者,因为缺省值的巨大尺寸而避免使用<h1>或<h2>,取而代之的是用更高数值的标题标签来实现更小的尺寸。 )VG>6x  
-!T24/l  
nnu#rtvZp}  
6&LmR75C  
然而,需要重点强调的是,我们可以很简单的用CSS来改变这些标题标签——举个例子,一个< ;h1>并非一定是占满大半屏幕的巨大标版。在后面,我将证明用CSS来样式化标题标签是多么的简单,希望可以帮助你减轻巨大的恐惧。 XdlA)0S)  
+g1+,?cU  
>#T?]5Z'MF  
8OS^3JS3"  
对搜索引擎友好的 _\@zq*E  
这是一个巨大的好处。搜索引擎喜欢标题标签。另一方面,一个<span>标签或者普通的加粗的段落标签却在意味着次要一点。适当的用<h1>到<h6>标记你的标题,只需要你的一点点努力,然而却让搜索引擎更容易的检索到你的页面,让人们最终能找到它们。 w!d(NA<|0]  
搜索引擎机器人会给予标题标签特别的关注——这是你可能放置一些关键词的地方。就象检索到 <title>和<meta>,它们会顺着标题标签往页面下面查找。如果你不使用这些标签,那么包含在里面的关键词将不会被认为是有价值的,从而被忽略掉。 !w!k0z]  
所以只要付出一点点的努力,你就能增加人们基于页面的内容找到你的站点的可能性。听上去不错,不是吗? % bdBg  
A3q#,%  
!iX/Ni:  
\|]+sQWQ  
关于标题的次序 #+h#b%8  
在范例中,这个特别的标题是页面中最重要的,因为它是文档的标题。因此,我们使用最重要的标题标签,<h1>。顺应W3C的规范,一些人认为跳过数个标题级是个不好的使用。举个例子,想象我们在下面的页面: Mbly-l{|  
D#Mz#\4o  
<O-R  
<h1>文章标题</h1> Y@Ry oJ  
我们接下去的标题(如果不是用另一个<h1>重复的话)应该是<h2>,然后是<h3 >,等等。你也许不应该在<h1>后面跳过一级,直接跟上<h3>。我倾向于同意以上的观点,顺着行文保持级别的连续性,来构造一个排版结构。这样的话,给一个已经存在的页面添加标题和样式就更容易了,你会减少因使用超出的数字而导致的错误。 t!FC)iY  
前面提到的,设计者也许会用<h4>来标签一个页面上最重要的标题,仅仅是因为它的缺省的字体尺寸不象<h1>那样令人生厌的巨大。但是记住,先结构,后设计。我们总是能用CSS来把标题样式化成任何我们喜欢的文字尺寸。

简单生活
执著追求
别笑我浅溥,天真的以为用一腔真诚就能感动这个冷漠的世界。
也别说我幼稚,竟想用不长的人生去诠释繁杂的红尘。
然而除了真诚,我还能给你什么,的确我真的一无所有!

级别: 店掌柜
发帖
5692
铜板
103378
人品值
1520
贡献值
26
交易币
0
好评度
5373
信誉值
0
金币
0
所在楼道

只看该作者 4 发表于: 2006-07-26
HTML4标签的默认样式列表 JnQ@uZb`  
w&hCt c  
[%Z{Mp'g  
?aB%h |VA  
html, address, VGCd)&s  
blockquote, &[PA?#I`  
body, dd, div, E3CwA8)k  
dl, dt, fieldset, form, KNF{NFk  
frame, frameset, < jX5}@`z  
h1, h2, h3, h4, *xx)j:Sc2  
h5, h6, noframes, r0\C2g_X  
ol, p, ul, center, {8;}y[R  
dir, hr, menu, pre   { display: block } $.ctlWS8l{  
li         { display: list-item } [ 'B u  
head         { display: none } ]h`d>#Hw!  
table       { display: table } z 7cA5'c  
tr         { display: table-row } a=B $L6*4  
thead       { display: table-header-group } %82:?fq  
tbody       { display: table-row-group } OwDwa~  
tfoot       { display: table-footer-group } (enOj0  
col         { display: table-column } Efpj u(   
colgroup     { display: table-column-group } an Kflt3  
td, th       { display: table-cell; } ?ZhBS3L  
caption       { display: table-caption } TOvsW<cM  
th         { font-weight: bolder; text-align: center } nF,zWr[x  
caption       { text-align: center } bXM&VW?OP  
body         { margin: 8px; line-height: 1.12 } \4fuC6d2  
h1         { font-size: 2em; margin: .67em 0 } %_39Wa  
h2         { font-size: 1.5em; margin: .75em 0 } ['6Sq@c)  
h3         { font-size: 1.17em; margin: .83em 0 } \2Q#'  
h4, p, R=iwp%c(  
blockquote, ul, ?2gXF0+~Y2  
fieldset, form, r. rzU  
ol, dl, dir, &< FKcrZ,  
menu         { margin: 1.12em 0 } +}mj;3i  
h5         { font-size: .83em; margin: 1.5em 0 } W:}t%agis  
h6         { font-size: .75em; margin: 1.67em 0 } }_+):<Db  
h1, h2, h3, h4, ij}{H#0S-  
h5, h6, b, {"N:2  
strong       { font-weight: bolder } j97K\]tQ  
blockquote     { margin-left: 40px; margin-right: 40px } yZmeke)_  
i, cite, em, U4iVI#f  
var, address   { font-style: italic } ],zp~yVU&  
pre, tt, code, AJoP3Zv|?  
kbd, samp     { font-family: monospace } h54\ \Ci  
pre         { white-space: pre }  {yxLL-5c  
button, textarea, oy=ej+:  
input, object, +R 8dy  
select       { display:inline-block; } m&MZn2u[4i  
big         { font-size: 1.17em } xaq/L:I<  
small, sub, sup { font-size: .83em } Q:ql~qew  
sub         { vertical-align: sub } }Os7[4 RW  
sup         { vertical-align: super } @JJ{\?>  
table       { border-spacing: 2px; } ,s,AkH  
thead, tbody, s`]SK^j0  
tfoot       { vertical-align: middle } G2=d q  
td, th       { vertical-align: inherit } 4~d:@Gmk&  
s, strike, del { text-decoration: line-through } Q[T)jo,j%  
hr         { border: 1px inset } D~2n8h"2ye  
ol, ul, dir, g6][N{xW0  
menu, dd     { margin-left: 40px } |B2>}Y/  
ol         { list-style-type: decimal } BG1hk!  
ol ul, ul ol, MTbCL53!-  
ul ul, ol ol   { margin-top: 0; margin-bottom: 0 } y8v0>V0)  
u, ins       { text-decoration: underline } kWC xc0  
br:before     { content: "\A" } h6 :|RGF  
:before, :after { white-space: pre-line } BGstf4v>A<  
center       { text-align: center } /1+jQS  
abbr, acronym   { font-variant: small-caps; letter-spacing: 0.1em } X9&>.?r  
:link, :visited { text-decoration: underline } Z3X9-_g  
:focus       { outline: thin dotted invert } 1_@vxi~aW_  
/* Begin bidirectionality settings (do not change) */ lvR>%I0`*  
BDO[DIR="ltr"] { direction: ltr; unicode-bidi: bidi-override } rF/<}ye/4M  
BDO[DIR="rtl"] { direction: rtl; unicode-bidi: bidi-override } &mba{O  
*[DIR="ltr"]   { direction: ltr; unicode-bidi: embed } |Fx~M,Pzg  
*[DIR="rtl"]   { direction: rtl; unicode-bidi: embed } 1b2xWzpG  
@media print { Xw162/:h  
h1         { page-break-before: always } T9>,Mx%D[  
h1, h2, h3, 4Ub7T=LG  
h4, h5, h6   { page-break-after: avoid } raR=k!3i  
ul, ol, dl   { page-break-before: avoid } _|COnm  
} HeHo?<>|d  
:?)q"hE  
uPb.uG  
anH]]  
Zo Ra^o  
-------------------------------------------------------------------------------- hXc:y0 0  
Bv 7os3xb  
同一个页面用多个id有什么影响 bhW&,"$Z  
)qDV3   
6ziBGU#.-  
[E qZj/  
 {C%f~j  
在样式表定义一个样式的时候,可以定义id也可以定义class,例如: 7lzmAih  
,Mn`kL<F  
ID方法:#test{color:#333333},在页面中调用<div id="test">内容<div> Ai`0Ud,M@  
CLASS方法:.test{color:#333333},在页面中调用<div class="test">内容<div> hdbm8C3  
id一个页面只可以使用一次,class可以多次引用。 [q|8.>sB  
~#=70  
有网友问,id和class好象没什么区别,我在页面中用了多个id在IE中显示也正常,用多个id有什么影响吗? ypTH=]y  
Rvj[Csgi  
回答:第一影响就是不能通过W3的校验。 T7(U6yN  
jGDuKb@:  
在页面显示上,目前的浏览器还都允许你犯这个错误,用多个相同ID“一般情况下”也能正常显示。但是当你需要用JavaScript通过id来控制这个div,那就会出现错误。 PJ)d5D%T  
q9nQ/]rkHF  
id是一个标签,用于区分不同的结构和内容,就象你的名字,如果一个屋子有2个人同名,就会出现混淆; MX|@x~9W  
class是一个样式,可以套在任何结构和内容上,就象一件衣服; _u#r;h[  
概念上说就是不一样的: 5^N` ~  
id是先找到结构/内容,再给它定义样式;class是先定义好一种样式,再套给多个结构/内容。 #*"I?B/fd8  
8HWEObRY  
web标准希望大家用严格的习惯来写代码, K/!>[d  
2:1 kSR^Ky  
例如:你可以用<b></b>显示粗体,也可以用<strong></strong>来显示,但W3C 建议大家用<strong>,因为<strong>更有语义

简单生活
执著追求
别笑我浅溥,天真的以为用一腔真诚就能感动这个冷漠的世界。
也别说我幼稚,竟想用不长的人生去诠释繁杂的红尘。
然而除了真诚,我还能给你什么,的确我真的一无所有!

级别: 店掌柜
发帖
5692
铜板
103378
人品值
1520
贡献值
26
交易币
0
好评度
5373
信誉值
0
金币
0
所在楼道

只看该作者 5 发表于: 2006-07-26
捷足先登学用CSS:HTML结构化 'D^@e0.3  
6^z):d#u  
!*,m=*[3  
你正在学习CSS布局吗?是不是还不能完全掌握纯CSS布局?通常有两种情况阻碍你的学习: E$4Ik.k  
wqJ1^>TB  
第一种可能是你还没有理解CSS处理页面的原理。在你考虑你的页面整体表现效果前,你应当先考虑内容的语义和结构,然后再针对语义、结构添加CSS。这篇文章将告诉你应该怎样把HTML结构化。 '.XR,\g>  
wHs4~"EY9  
另一种原因是你对那些非常熟悉的表现层属性(例如:cellpadding,、hspace、align="left"等等)束手无策,不知道该转换成对应的什么CSS语句。当你解决了第一种问题,知道了如何结构化你的HTML,我再给出一个列表,详细列出原来的表现属性用什么CSS来代替。 @-O%u* %J  
r3~YGY  
结构化HTML =^w:G=ymS  
我们在刚学习网页制作时,总是先考虑怎么设计,考虑那些图片、字体、颜色、以及布局方案。然后我们用Photoshop或者Fireworks画出来、切割成小图。最后再通过编辑HTML将所有设计还原表现在页面上。 v2vtkYQN  
)yS S2  
如果你希望你的HTML页面用CSS布局(是CSS-friendly的),你需要回头重来,先不考虑“外观”,要先思考你的页面内容的语义和结构。 ;Hu`BFXyD  
I5W#8g!{  
外观并不是最重要的。一个结构良好的HTML页面可以以任何外观表现出来,CSS Zen Garden是一个典型的例子。CSS Zen Garden帮助我们最终认识到CSS的强大力量。 2-rfFqpe  
|1m2h]];Q  
HTML不仅仅只在电脑屏幕上阅读。你用photoshop精心设计的画面可能不能显示在PDA、移动电话和屏幕阅读机上。但是一个结构良好的HTML页面可以通过CSS的不同定义,显示在任何地方,任何网络设备上。 \*30E<;C_  
3Zm;:v4y  
开始思考 88zK)k{  
首先要学习什么是"结构",一些作家也称之为"语义"。这个术语的意思是你需要分析你的内容块,以及每块内容服务的目的,然后再根据这些内容目的建立起相应的HTML结构。 E>YE3-]  
rKr\Qy+q  
如果你坐下来仔细分析和规划你的页面结构,你可能得到类似这样的几块: O?Qi  
j"vL$h  
标志和站点名称 }`_x%]EJ  
主页面内容 _Hv@bIL'  
站点导航(主菜单) 'c$)}R I7  
子菜单 Az6tu <  
搜索框 G=m18Bv{  
功能区(例如购物车、收银台) mzn#4;m$  
页脚(版权和有关法律声明) W;.L N<bx  
我们通常采用DIV元素来将这些结构定义出来,类似这样: q]gF[&QZ  
er2#h  
<div id="header"></div> ifadnl26 s  
<div id="content"></div> Gp1?drF6  
<div id="globalnav"></div> eMUt%zvb  
<div id="subnav"></div> BBj>ML\X  
<div id="search"></div> 3Sn# M{wH  
<div id="shop"></div> Q'Y7PG9m~  
<div id="footer"></div> Ym9~/'%]  
 9 -Xr  
这不是布局,是结构。这是一个对内容块的语义说明。当你理解了你的结构,就可以加对应的ID在DIV上。DIV容器中可以包含任何内容块,也可以嵌套另一个DIV。内容块可以包含任意的HTML元素---标题、段落、图片、表格、列表等等。 (6i. >%|_  
=la~D]T*g  
根据上面讲述的,你已经知道如何结构化HTML,现在你可以进行布局和样式定义了。每一个内容块都可以放在页面上任何地方,再指定这个块的颜色、字体、边框、背景以及对齐属性等等。 ;2547b[ ]  
AL[,&_&uV  
使用选择器是件美妙的事 -\8v{ry  
id的名称是控制某一内容块的手段,通过给这个内容块套上DIV并加上唯一的id,你就可以用CSS选择器来精确定义每一个页面元素的外观表现,包括标题、列表、图片、链接或者段落等等。例如你为#header写一个CSS规则,就可以完全不同于#content里的图片规则。 !InC8+be  
77%I%<#  
另外一个例子是:你可以通过不同规则来定义不同内容块里的链接样式。类似这样:#globalnav a:link或者 #subnav a:link或者#content a:link。你也可以定义不同内容块中相同元素的样式不一样。例如,通过#content p和#footer p分别定义#content和#footer中p的样式。从结构上讲,你的页面是由图片、链接、列表、段落等组成的,这些元素本身并不会对显示在什么网络设备中(PDA还是手机或者网络电视)有影响,它们可以被定义为任何的表现外观。 %"AB\lL.  
:Gf  
一个仔细结构化的HTML页面非常简单,每一个元素都被用于结构目的。当你想缩进一个段落,不需要使用blockquote标签,只要使用p标签,并对p加一个CSS的margin规则就可以实现缩进目的。p是结构化标签,margin是表现属性,前者属于HTML,后者属于CSS。(这就是结构于表现的相分离.) KOhIk*AC '  
TL: 6Pe  
良好结构的HTML页面内几乎没有表现属性的标签。代码非常干净简洁。例如,原先的代码<table width="80%" cellpadding="3" border="2" align="left">,现在可以只在HTML中写<table>,所有控制表现的东西都写到CSS中去,在结构化的HTML中,table就是表格,而不是其他什么(比如被用来布局和定位)。 R(GL{Dh}L  
+3r4GEa Z  
亲自实践一下结构化 +w(B9rH  
上面说的只是最基本的结构,实际应用中,你可以根据需要来调整内容块。常常会出现DIV嵌套的情况,你会看到"container"层中又有其它层,结构类似这样: 6f;20dn 6  
m@g9+7  
<div id="navcontainer"> evz@c)8  
<div id="globalnav"> +{s -Fg  
<ul>a list</ul> a7TvX{<d  
</div> i0&W}Bb'  
<div id="subnav"> "Pzh#rYY~W  
<ul>another list</ul> WI-I+0sE  
</div> _{?-=<V'_  
</div> m 8P`n  
;~n^/D2.  
嵌套的div元素允许你定义更多的CSS规则来控制表现,例如:你可以给#navcontainer一个规则让列表居右,再给#globalnav一个规则让列表居左,而给#subnav的list另一个完全不同的表现。

简单生活
执著追求
别笑我浅溥,天真的以为用一腔真诚就能感动这个冷漠的世界。
也别说我幼稚,竟想用不长的人生去诠释繁杂的红尘。
然而除了真诚,我还能给你什么,的确我真的一无所有!

级别: 店掌柜
发帖
5692
铜板
103378
人品值
1520
贡献值
26
交易币
0
好评度
5373
信誉值
0
金币
0
所在楼道

只看该作者 6 发表于: 2006-07-26
WEB标准教程 第1天:选择什么样的DOCTYPE \ 9#X]H  
*fQn!2}=(  
第一天 y`J8hawp  
#E4|@}30`  
开始制作符合标准的站点,第一件事情就是声明符合自己需要的DOCTYPE。 PgYIQpV  
&|fWtl;43  
'oF('uR  
查看本站首页原代码,可以看到第一行就是: oe[f2?-  
:O]US)VSj  
aJ J63aJ  
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> f;obK~b[  
}[SYWJIc  
O<y65#68Z  
SL?YU(a  
打开一些符合标准的站点,例如著名web设计软件开发商Macromedia,设计大师Zeldman的个人网站,会发现同样的代码。而另一些符合标准的站点(例如k10k.net)的代码则如下: !>)o&sM  
* 5(%'3  
ma@!"Z8 S  
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Frameset//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd"> JHg y&/  
[rReBgV  
\/R $p  
那么这些代码有什么含义?一定要放置吗? 0t6DD  
Te7xj8<  
C(2kx4n  
什么是DOCTYPE mi@ni+2Tn  
!JA//{?  
上面这些代码我们称做DOCTYPE声明。DOCTYPE是document type(文档类型)的简写,用来说明你用的XHTML或者HTML是什么版本。 ` pfRY!  
| &/_{T  
e;9x%kNs!  
其中的DTD(例如上例中的xhtml1-transitional.dtd)叫文档类型定义,里面包含了文档的规则,浏览器就根据你定义的DTD来解释你页面的标识,并展现出来。 W;|%)D)y  
@nIoIz D~  
8+8L'Yv;  
要建立符合标准的网页,DOCTYPE声明是必不可少的关键组成部分;除非你的XHTML确定了一个正确的DOCTYPE,否则你的标识和CSS都不会生效。 E_Fm5zb?X  
T%w5%{dqJ  
=-/sB>-C  
XHTML 1.0 提供了三种DTD声明可供选择: eZ{Ce.lNR  
I6PReVIb  
qD,/Qu62  
Dw<bLSaW&  
过渡的(Transitional):要求非常宽松的DTD,它允许你继续使用HTML4.01的标识(但是要符合xhtml的写法)。完整代码如下: D_ XOYzN}  
n2Ew0-  
g1)ZjABV  
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> k zC4V  
ogJ *  
$>rKm  
+HlZ ?1g  
严格的(Strict):要求严格的DTD,你不能使用任何表现层的标识和属性,例如<br>。完整代码如下: 9hjzOJPuga  
Zm6|aHx8v  
+g_m|LF  
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> ym'!f|9AA  
Wjr^: d  
Av!xI  
|v_ttJ;+Y  
框架的(Frameset):专门针对框架页面设计使用的DTD,如果你的页面中包含有框架,需要采用这种DTD。完整代码如下: &.P G2f*  
HF*j=qt!  
n _kE  
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Frameset//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd"> HJt '@t=Ak  
6xx(o  
Wu'9ouw!  
我们选择什么样的DOCTYPE A[uB)wWsn  
Jv?EV,S/e  
理想情况当然是严格的DTD,但对于我们大多数刚接触web标准的设计师来说,过渡的DTD(XHTML 1.0 Transitional)是目前理想选择(包括本站,使用的也是过渡型DTD)。因为这种DTD还允许我们使用表现层的标识、元素和属性,也比较容易通过W3C的代码校验。 */4hFD {  
g nw">H  
A[m<xtm5K  
注:上面说的"表现层的标识、属性"是指那些纯粹用来控制表现的tag,例如用于排版的表格、背景颜色标识等。在XHTML中标识是用来表示结构的,而不是用来实现表现形式,我们过渡的目的是最终实现数据和表现相分离。 co-1r/ -O  
$Ww.^ym  
RSCQ`.  
打个比方:人体模特换衣服。模特就好比数据,衣服则是表现形式,模特和衣服是分离的,这样你就可以随意换衣服。而原来HTML4中,数据和表现是混杂在一起的,要一次性换个表现形式非常困难。呵呵,有点抽象了,这个概念需要我们在应用过程中逐步领会。 Hp[i8PJ  
FmgMd)#  
fpJ%{z2  
补充 Xq}}T%jcd  
sK8sxy  
DOCTYPE声明必须放在每一个XHTML文档最顶部,在所有代码和标识之上。

简单生活
执著追求
别笑我浅溥,天真的以为用一腔真诚就能感动这个冷漠的世界。
也别说我幼稚,竟想用不长的人生去诠释繁杂的红尘。
然而除了真诚,我还能给你什么,的确我真的一无所有!

级别: 店掌柜
发帖
5692
铜板
103378
人品值
1520
贡献值
26
交易币
0
好评度
5373
信誉值
0
金币
0
所在楼道

只看该作者 7 发表于: 2006-07-26
XHTML基础问答 OxUc,%e9P  
5F#FC89Kk  
yT[=!M  
HTML语言是我们建立网页的工具,从它出现发展到现在,规范不断完善,功能越来越强。但是依然有缺陷和不足,人们仍在不断的改进它,使它更加便于控制和有弹性,以适应网络上日新月异的应用需求。2000年底,国际W3C(World Wide Web Consortium)组织公布发行了XHTML 1.0版本,XHTML和HTML,XML有什么不同,它增加了什么新功能,今天就让我们来初步认识一下XHTML。 -Ua&/Yd/}  
Z/d {v:)  
^ 4*#QtO  
  XHTML 1.0是一种在HTML 4.0基础上优化和改进的的新语言,目的是基于XML应用。XHTML是一种增强了的HTML,它的可扩展性和灵活性将适应未来网络应用更多的需求。下面是W3C的HTML工作组主席Steven pemberton回答的关于XHTML的常见基础问题。 s"p\-Z  
z<gII~%  
TeFi[1  
  问:什么是XHTML? 4gZ)9ya   
\["I.gQ  
b*ja,I4  
  答:XHTML是一种为适应XML而重新改造的HTML。当XML越来越成为一种趋势,就出现了这样一个问题:如果我们有了XML,我们是否依然需要HTML?为了回答这个问题,1998年5月我们在旧金山开了两天的工作会议,会议的结论是:需要。我们依然需要使用HTML。因为大量的人们已经习惯使用HTML来作为他们的设计语言,而且,已经有数以百万计的页面是采用HTML编写的。 ;te( {u+  
0[ (kFe  
D[)_ f  
  问:为什么XHTML 1.0相对HTML 4.0独立发展? F<Xtp8  
a'r1or4  
}KT$J G?  
  答:并不是这样。XHTML恰恰就是HTML 4.0的重新组织,(确切的说它是HTML 4.01,是一个修正版本的HTML 4.0,只不过以XHTML 1.0命名发行。) 它们在XML里的解释会有一些必要的差别,但另一方面,它们依然非常相似,我们可以把XHTML的工作看作是HTML 4.0基础上的延续。 UhJ!7Ws$  
5 9i2*<k  
E6M*o+Y  
  问:XHTML 1.0如何实现XML标准? <'\!  
7spZe"  
O%w'n z"  
  答:XHTML就是一种XML应用。它采用XML的DTD文件格式定义,并运行在支持XML的系统上。这里要感谢XML的Namespaces功能,浏览器制造商不需要再创造新的私有标签(tags),他们只需要在XHTML代码里包含XML代码片段,或者XML代码里包含XHTML代码片段。 204"\ mv  
#qv!1$}2  
=Aw`0  
  问:XHTML 1.0最主要的优势是什么? 1DGl[k/zv  
Z[>fFg~N4  
8U}+9  
  答:XML是web发展的趋势,所以人们急切的希望加入XML的潮流中。使用XHTML 1.0,只要你小心遵守一些简单规则,就可以设计出既适合XML系统,又适合当前大部分HTML浏览器的页面。这个意思就是说,你可以立刻设计使用XML,而不需要等到人们都使用支持XML的浏览器。这个指导方针可以使web平滑的过渡到XML。 I'[;E.KU  
6OqF-nso[E  
umCmxm r&  
  另一个使用XHTML的优势是:它非常严密。当前网络上的HTML的糟糕情况让人震惊,早期的浏览器接受私有的HTML标签,所以人们在页面设计完毕后必须使用各种浏览器来检测页面,看是否兼容,往往会有许多莫名其妙的差异,人们不得不修改设计以便适应不同的浏览器。 D !{e  
_9q byhS7  
 cp0yr:~  
  用XML我们可以重新建立制度,浏览器制造商联合采用"严格的错误防御标准",如果XML代码不兼容,浏览器拒绝显示页面,这样设计工作在发布前必须修正每一个错误。 A4Q{(z-?  
5rmQ:8_5  
0.2stBw  
  问:用XHTML,网页设计师会遇到和HTML一样的浏览器兼容性问题吗? HZ1nuA  
MhJA8| B6|  
5sNN:m  
  答:希望不会。"严格的错误防御标准"将帮助浏览器对代码作出相同的响应,XML的namespaces功能使你可以增加自己的新标签而不需要特别的浏览器支持。现在我们所需要得到保证的就是:所有浏览器开发商一致并且完全遵守我们制定的CSS。写信给你的浏览器制造商,告诉你需要的CSS规范,你甚至可以检测浏览器是否听从你的设计。 "c.-`1,t  
bh#6yvpMR  
db&!t!#,  
  问:学习XHTML是否很困难? \S&OAe/b  
%(]B1Zg6,  
D1@yW} 4  
  答:一点也不! |<O^M q  
F{rC{5@fj  
*9aI\#}  
  问:谁可以采用XHTML 1.0设计? <$d2m6J  
vP=H 2P  
yr?X.Np  
  答:因为XHTML非常简单易于实现,所以任何会用HTML的人都可以容易地使用XHTML。当使用XML浏览器的人们越来越多,更多的工作会被建议使用XML,那时侯也许都将使用XHTML。 m/,80J8L+f  
 J%T=FU  
U@D\+T0  
  问:什么时候XHTML网站会普及? Spin]V  
C ](djkA$  
pG'?>]Rt4  
  答:好问题。我已经看到一些使用XHTML建立的网站,甚至在XHTML 1.0发布以前。我相信它将会有一个大发展,因为它太容易了。 2EYWX! Bx  
Y*{5'q+2  
0d1!Q!PH3  
  问:我们如何将现有的HTMl转换为XHTML? S!b?pl  
p.b#RY  
>[:qJ|i%  
  答:非常简单,因为它们非常相似。在W3C(www.w3c.org)网站上有一个开放原代码(open-source)的软件叫HTML Tidy,可以帮助你直接转换。 H!Dj.]T  
_!Pi+l4p/}  
D7m uf  
  问:XHTML未来会怎样? H328I}7  
ivB,s5<  
,~DKU*A_~  
  答:XHTML1.0仅仅是这个新HTML语言的第一步。新版本将没有向下兼容老浏览器的约束,可以有更多的发展空间。 )u4=k(  
]7oo`KcQ|  
?GqH/ (O  
  首先,我们将进行一次彻底的清理,删除HTML 4.0中不兼容的元素。 $yq76  
.}T-R?  
#_ UP}G$  
  其次,我们将XHTML模块化,允许人们在XML应用中使用XHTML模块(比如表格),减少重复开发。同时也允许开发特别用途的设计,比如电话应用,只要属于XHTML的子集就可以保持兼容,人们可以创造他们自己的HTML。 *ae)<l3v  
lY2~{Y|4s  
u J]uz%  
  最后,在解决需求方面,我们将开发更多的表单(Forms)功能,允许在客户端执行更多的检测,减少客户机--服务器之间的网络信息传输。总之,更多令人兴奋的功能将会被实现。

简单生活
执著追求
别笑我浅溥,天真的以为用一腔真诚就能感动这个冷漠的世界。
也别说我幼稚,竟想用不长的人生去诠释繁杂的红尘。
然而除了真诚,我还能给你什么,的确我真的一无所有!

级别: 店掌柜
发帖
5692
铜板
103378
人品值
1520
贡献值
26
交易币
0
好评度
5373
信誉值
0
金币
0
所在楼道

只看该作者 8 发表于: 2006-07-26
典型的三行二列居中高度自适应布局 (`4&Y-  
gm =C0Sp?  
wy{ sS}  
;PnN$g]Q  
-------------------------------------------------------------------------------- R3.w")6  
f`_{SU"3  
f9 :=6  
这个页面在mozilla、opera和IE浏览器中均可以实现居中和高度自适应。我们来分析代码: /-t!)_zvw  
a>9_#_hI  
完整代码 <:T/hm$  
[>\e@ =  
<html> dLeos9M:  
XKDX*x G  
[2>zaag  
9I$} =&"  
<head> _n{_\/A6f  
UEt78eN  
H q?F@X  
?L H[,8z  
<style type="text/css"> cfRUVe  
N}<!k#d E  
~ 4Mz:h^  
g0;;+z  
body{ |T/s>OW  
p$= 3$I  
S3$C#mHX  
nEW.Y33  
background:#999; [*I7^h%  
DiY74D  
%s9*?6  
wZ69W$,p  
text-align:center; a/H5Y,b>  
ZNpC& "`G  
A$n.'*gK  
!q$>6P  
color: #333; g& f)WQ(  
-3wid1SOm  
Aq7`A^1t$  
)OucJQ  
font-family:arial,verdana,sans-serif; 0pl'*r*9  
"u&7Y:)^wr  
\2#K {  
Pn4jI(  
} ( ]0F3@k#s  
vb]uO ' l  
W(?J,8>  
2V$Jn8v,`{  
#header{ lUp%1x+  
.sOZ"=tW  
m=v.<+>  
c&aqN\'4"  
width:776px; 4:733Q3oK  
G`&P|xYg  
mA_EvzXk\  
;-l^X%r  
margin-right: auto; |nr;OM  
}H saJ=1U  
RBg2iG$ 8|  
4 >H0a  
margin-left: auto; U3v~R4  
X56q ,jCJ{  
&gJ@"`r4  
|u$*'EsP  
padding: 0px; w)1SZ }  
WE_'u+!B  
sSD&'K=lq  
yd'cLZd<}  
background: #EEE; B# .xs>{N  
H4{7,n  
'O9Yu{M  
LWSy"Cs*  
height:60px; 3m2y<l<  
dl |$pm@x  
h.Sbds  
s|Vs#o.P)  
text-align:left; .i*ja*   
NS+uiy  
-em3 #V  
1rU\ !GfR  
} #contain{ B6\/xKmv?8  
S$R=!3* "V  
eb,QT\/G  
^h#A7 g  
margin-right: auto; + iQ~ Y2Gh  
K;s`  
wN6sica|  
`/wXx5n5<  
margin-left: auto; ~x_(v,NW  
xlgT1b:6  
?qn4 ea-\P  
C:bA:O  
width: 776px; <S;YNHLC  
XRyeEwA;pp  
zJ ;]z0O  
Z3ODZfu>  
} #mainbg{ W=|'&UU Ul  
XuZgyt"=r  
>s,*=a  
Pl#u ,Y  
width:776px; L;b-=mF  
(5[#?_~  
36.mf_AM  
6(1 &6|o3  
padding: 0px; S_VzmCi  
-~lrv#5Q  
!VrBoU4<d  
!}1l8Y  
background: #60A179; R_Bf JD.  
=FFs8&PKys  
o$*DFvk  
CPP9=CoR37  
float: left; SL^%Zh/~  
kjQI=:i=  
Ml +f3#HP  
8 -b~p  
} 6G-XZko~a  
K+yi_n L  
p{SIGpbR&  
Esg:  
#right{ 2elj@EB,M  
F[.IF5_  
gK dNgU  
"[Tr"nI  
float: right; Kj6+$l   
6e}T zc\@(  
A?)(^  
nRX<$OzTV  
margin: 2px 0px 2px 0px; 3z8zZ1uzU  
l|9'l[}&  
f\~w!-  
xu;^F  
padding:0px; }ASBP:c"t  
: R8+jO   
y92<(ziaX)  
>4#\ U!  
width: 574px; d{C8}U  
U2JxzHXZ  
y>RqA *J  
j{zVVT  
background: #ccd2de; ' 94HVag  
T16B2|C"Y  
:+ "JPF4X  
2Paw*"U  
text-align:left; #KtV4)(  
P|aSbsk:I<  
FOcDBCrOe  
ab6D&  
} >v%UV:7ap  
];0:aSi#  
EkN>5).  
gJzS,g1]  
#left{ i\MW'b  
m :]F &s  
QkO4Td<  
#P1 ;*m  
float: left; YeF'r.Y  
.+^o{b  
<R#:K7> O  
wKz*)C  
margin: 2px 2px 0px 0px; 8[8U49V9(  
jqoU;u`  
U(:t$SBKy  
#mO.[IuD  
padding: 0px; vF@.B M>  
|'#uV)b0@  
+Pn`AV1  
k_%maJkXp  
background: #F2F3F7;  6AmFl<  
l02aXxT)]  
P$G|o|h  
W8!8/ IZbN  
width: 200px; lx~mn~;x  
lt}U,p,S  
@gJPMgF$F  
K%vGfQ8Er-  
text-align:left; UAdj [m61  
/B  
jbTyM"Y  
j!`2Z@  
} zU};|Zw  
V0:db  
VU|Cct&)  
I~c}&'V  
#footer{ DAd$u1  
9, 792b  
N{zou?+  
E`uK7 2j  
clear:both; /s`xPxvt  
3-2?mV>5  
C6b(\#g(  
Xec U&  
width:776px; _Hq)mF  
gr$H?|n l  
)i>T\B  
H*>5ne=x  
margin-right: auto; . J*2J(T,  
K+c>Cj}H  
;4]l P  
~bJ*LM?wOP  
margin-left: auto; gJBk&SDgtP  
*yA. D?  
Bk~M^AK@~  
.'N#qs_  
padding: 0px; {eo?vA8SE  
/?QBMI  
oI%.oP}G  
:~9F/Jx  
background: #EEE; w9a6F  
MT@Uu  
SkA"MhX  
'~'3x4Bo  
height:60px;} @BXV>U2B{  
tA{<)T  
T k4"qGC.  
V?cUQghHg  
.text{margin:0px;padding:20px;} =p';y&   
rhvsd2 zi  
6T~xjAuJ3T  
SYTzJK@vZJ  
</style> DnPV Tp(>  
cj/FqU"  
nyB~C7zR  
bDPT1A`F  
</head> _Msaub!N  
/-ky'S9  
 Z@`HFZJ  
E^. =^bR  
<body> m,]M_y\u  
_&m   
-vC?bumR%  
}' t*BaU  
<div id="header">header</div> Zx]"2U#  
OC[(Eq  
2]*2b{gF,  
ffYiu4$m  
<div id="contain"> Au/n|15->C  
1%6}m`3  
CR$5'#11)  
mWM!6"  
<div id="mainbg"> ZK]C!8\2|  
|bz,cvlP W  
]={{$}8.  
+<H)DPG<  
<div id="right"> -.E<~(fad  
hw&R .F  
*l^%7W rk  
4<&`\<jZ  
<div qcfLA~y  
_ #+~#U%5n  
up7]Yy;o=  
L1k_AC1.M  
class="text">right<p>1</p><p>1</p><p>1</p><p>1</p><p>1</p></div> <[7.+{qfW  
f"5vpU^5*  
[nlW}1)46  
QY<2i-A  
</div> X^H)2G>e  
Dl%NVi+n  
6^.<5SJ}  
O(PG"c  
<div id="left"> u-7/4Y)c  
U.G**v  
;[@< ,  
Ui 7S8c#tH  
<div class="text">left</div> u1&pJLK0[  
^1S(6'a#  
]W%<<S  
/ %U+kW  
</div> e;<=aa)}?  
!285=cxz  
wvA@\-.+  
amIG9:-1'  
</div> v >71 ?te  
rr# &0`]  
Khxl 'qj  
ALiXT8q  
</div> \5Jpr'mY5  
m$:o+IH/  
b{t'Doe  
}cG!93  
<div id="footer">footer</div> 7!`,P  
snV,rZ  
t3b%f`D  
N$H0o+9-Y  
</body> AjK'P<:/  
g#1_`gK  
969*mcq'  
_*+ 7*vAL  
</html> %@5f+5{i!z  
Qe=!'u.nL  
`|;R}"R;  
[= -?n6  
~fE@]~f>  
_d&FB~=  
<head> 5TVDt  
},'2j  
hof:+aW  
ajW[}/)  
<style type="text/css"> 0*q&)  
c?CjJ}-7  
XU .FLNe  
WLEjRx  
body{ uHUicZf.  
V7!x-E/  
o@r+Y  
e qQAst#~  
background:#999; E3y"  
ewSFB< N  
T"XP`gk  
G_g~-[O  
text-align:center; J A ]s  
HKCMKHR  
i3*S`/]p  
" ;cWK29\f  
color: #333; nW3`Z1kq})  
?C6iJnm  
vW 0m%  
b,8W |  
font-family:arial,verdana,sans-serif; Pm6/sO  
lN)U8  
{mMrD 5  
T&I*8 R~  
} !j6]k^ra  
NWSBqL5v   
q3B#rje>h  
>z1RCQWju  
#header{ O2?ye4uq  
._"U{ f2V  
eZ y)>.6Z  
 ;OQ{  
width:776px; |0ahvsrtW  
Funep[rA  
X~GnK>R  
v&%GK5j7O  
margin-right: auto; ] FvN*@lG  
[nxjPx9-  
SEF/ D0  
W\o(f W  
margin-left: auto; eP$0TDZ  
xXM`f0s@+]  
]QM6d(zDA  
)Fk%, H-1  
padding: 0px; =9GL;z:R+  
0Np }O=>  
9`+c<j4/B  
Uwr inkoeE  
background: #EEE; I|,^a|\  
2GA6@-u\  
8'_>A5L/C  
MOY.$M,1  
height:60px; sXkWs2!  
%p)6m 2Sb  
f@+[-yF  
as- Z)h[B  
text-align:left; &!vJ3:  
abUvU26t  
)V%xbDdS  
(Sr&Y1D  
} #contain{ pj G6v(zK  
z _~f/  
&i4*tE3],  
Gvw4ot/  
margin-right: auto; ~mx me6"v  
7OG=LF*V-  
M2_sxibI  
jzSh|a9_  
margin-left: auto; P Ig)h-w?  
_ro^<V$%  
 8Br*  
 ;?1H&  
width: 776px; UP}Y s*  
W)ihk\E  
sH(4.36+  
r.0IC*Y  
} #mainbg{ Q\ TawRK8  
}BS.OK?  
%*lOzC  
T~7i:<E^  
width:776px; 7R[4XQ%  
nellN}jYsM  
ehl) {Dd^  
-$J\BkI  
padding: 0px; #"fBF/Q  
N%%2!Z#  
;ajCnSmR  
'{p/F $  
background: #60A179; la>:%SD  
;BUJ5  
4=td}%  
CTQF+Oe8O  
float: left; b26#0;i  
fi^ I1*S  
b[<r+e8  
`@q[&^  
} %>Z^BM<e  
l^w=b~|7=  
Nl,M9  
xQ9P'ru  
#right{ X:bv ?o>Y  
~q4KQ&.!  
%bgjJ`  
"i_I<?aGB  
float: right; #'fh'$5"  
t=o0 #jo  
lxx)l(&  
qk;*$Q  
margin: 2px 0px 2px 0px; u+UtvzUC  
5drc8_fZ  
@H2c77%  
q`_d>l  
padding:0px; je@F:5  
B:#5U85m  
W~(@*H  
7Vd"k;:X  
width: 574px; Rd@34"O  
V TQ V]>|  
A5cx!h  
NFw7g&1;Kp  
background: #ccd2de; cih@: =Qy  
|VxEW U/  
VI7f}  
)Kkw$aQI"d  
text-align:left; Dn~r~aR$g  
G66sP w  
"S)2<tV  
<qjNX-|  
} f#mBMdj  
/8(c^  
~XGBE  
I[,tf!  
#left{ dCv@l7hE  
cO/%;HEV  
e^2e[rp0  
ya7PF~:E-  
float: left; F5la:0fb  
7Mq4$|qhD  
q)vdDdRe_  
zmd,uhNc:  
margin: 2px 2px 0px 0px; )a"rj5~-  
X^;[X~g  
%;ZWYj`]n  
w/_n$hX  
padding: 0px; `2N&{(  
@a-u_|3q  
C_xO k'091  
WeyH;P=  
background: #F2F3F7; ; ^+#  
8>^(-ca_  
C><]o  
-(*<2Hy4  
width: 200px; eS)2#=  
uG<VQ2LM  
W*?mc2;/  
Tj5G /H>   
text-align:left; JHQc)@E}  
=P'33) \ )  
vxuxfi8x  
!R p  
} W=b<"z]RE  
%B9iby8)1  
\i1>/`F  
lS1-e0,h1  
#footer{ $7M/rF;N5X  
~DY5`jV  
O`Ht|@[6  
CUJP"u>8M  
clear:both; :eIPPh|\  
&XG k  
kkWqP20q  
1K(a=o[Ce  
width:776px; S}fU2Wi  
QY14N{]T\p  
"s-e)svB  
<3?T^/8  
margin-right: auto; Ce&nMgd~  
o=/Cje  
Twqkd8[  
9J>b6   
margin-left: auto; (EZ34,k'S  
?naPti1GX  
p#-ov-znp  
5vxKkk&i4l  
padding: 0px; Hgu:*iYA  
H<tk/\C  
<eWGvIEP[  
$xx5+A%,  
background: #EEE; 38Rod]\E  
$7Sbz&)y3  
#bRr|`  
;VQFz&Q$u  
height:60px;} JiFy.Pf  
W40GW  
oL?[9aww  
t:A,pT3  
.text{margin:0px;padding:20px;} 00DWXGt20o  
$#Mew:J  
1-z*'Ghys  
xL.T}f~y2>  
</style> {sn:Lj0  
'Na \9b(  
-I, _{3.S  
44s K2  
</head>  ]J= S\  
k:?+75?$  
eFO+@  
n])-+[F  
<body> M~&|-Hm  
#3uBq(-Z  
>z=_V|^$  
o;#{N~4[$  
<div id="header">header</div> W@S'mxk#*  
= mn jIp  
m~K[+P  
HSt|Ua.c/h  
<div id="contain"> kBPFk t2  
m7:E7 3:  
Salu[)+?  
%}z/_QZ  
<div id="mainbg"> xP@VK!sc  
` eB-C//  
1[k~*QS  
9JF*xXd>Q  
<div id="right"> )9,*s !)9  
2>{_O?UN  
\L#BAB6z  
uj.~/W1,!  
<div Lh=~3  
WY@x2bBi  
9"yBO`  
=k4yWC5-  
class="text">right<p>1</p><p>1</p><p>1</p><p>1</p><p>1</p></div> /Vpd*obMB  
cz_4cMgxu  
lYd#pNN  
kndP?#> p1  
</div> b0a'Y"oef4  
Z$R2Z$f  
{HqwpB\@  
Df_W>QC  
<div id="left"> &`7~vA&c  
':,6s  
I3Sl>e(Z  
 1fbd/-h  
<div class="text">left</div> fgxsC7P$  
c$f|a$$b   
ixJUq o  
-_jV.`t  
</div> inBd.%Yr  
kO<`RHlX=  
mRCgKW<  
R|Ft@]  
</div> =#XsY,r  
A!v-[AI[  
CiP-Zh[gZ  
@S~'m;  
</div> }iy`Ko+B"b  
$ql-"BB  
_ED1".&#f  
(.,E6H|zI  
<div id="footer">footer</div> - Pz )O@ ;  
^_<>o[qE  
IidZ -Il  
u)P$xkf  
</body> 3&*0n^g  
rL URP2~  
y? [*qnPj  
F~d !Ub$>  
</html>

简单生活
执著追求
别笑我浅溥,天真的以为用一腔真诚就能感动这个冷漠的世界。
也别说我幼稚,竟想用不长的人生去诠释繁杂的红尘。
然而除了真诚,我还能给你什么,的确我真的一无所有!

级别: 店掌柜
发帖
5692
铜板
103378
人品值
1520
贡献值
26
交易币
0
好评度
5373
信誉值
0
金币
0
所在楼道

只看该作者 9 发表于: 2006-07-26
P7\(D`  
p)ZlQ.d#Y  
首先我们定义body和顶部第一行#header,这里面的关键是body中的text-align:center;和header中的margin-right: auto;margin-left: auto;,通过这两句使得header居中。注:其实定义text-align:center;就已经在IE中实现居中,但在mozilla中无效,需要设置margin:auto;才可以实现mozilla中的居中。 _| 8"&*T^  
接下来定义中间的两列#right和#left。为了使中间两列也居中,我们在它们外面嵌套一个层#contain,并对contain设置margin:auto;,这样#right和#left就自然居中了。 jTw s0=F*  
注意中间两列定义的顺序,我们首先定义#right,通过float: right;让它浮在#contain层的最右边。然后再定义#left,通过float: left;让它浮动在#right层的左面。这和我们以前表格从左到右定义的顺序正好相反。 wri[#D {  
我们看到代码中在#contain和两列之间还嵌套了一个层#mainbg,这个层是做什么用的呢?这个层就是用来定义#contain的背景的。你肯定会问,为什么不直接在#contain中定义背景,而要多套一层呢?那是因为在#contain中直接定义的背景,在mozilla中将显示不出来,必须定义高度值才可以。如果定义了高度值,#right层就无法实现根据内容的自动伸缩。为了解决背景和高度问题,就必须增加这么一个#mainbg层。窍门在于#mainbh这个层定义float: left;,因为float使层自动有宽和高的属性。(暂且这么理解:) `Uk,5F5   
最后是定义底部的#footer层。这个定义的关键是:clear:both;,这一句话的作用是取消#footer层的浮动继承。否则的话,你会看到#footer紧贴着#header显示,而不是在#right的下面。 sSG]I%oB3  
主要的层定义完毕,这个布局就ok了。补充一点:你看到我还定义了一个.text{margin:0px;padding:20px;},这个class的作用是使内容的外围有20px的空白。为什么不直接在#right里定义margin或者padding呢,因为mozilla和IE对css盒模型的解释不一致,直接定义margin/padding会造成mozilla里布局变形。一般采用内部再套一层的做法来解决。

简单生活
执著追求
别笑我浅溥,天真的以为用一腔真诚就能感动这个冷漠的世界。
也别说我幼稚,竟想用不长的人生去诠释繁杂的红尘。
然而除了真诚,我还能给你什么,的确我真的一无所有!

级别: 店掌柜
发帖
5692
铜板
103378
人品值
1520
贡献值
26
交易币
0
好评度
5373
信誉值
0
金币
0
所在楼道

只看该作者 10 发表于: 2006-07-26
使用DIV之后,什么时候使用TABLE any\}   
*ep!gT*4  
关于表格 Tf@t.4\  
Q\=u2}/z0  
lRt8{GFy  
  使用WEB标准之后,并不是说排除表格的使用,表格并不是鸡肋,而正好相反是一道大餐,之所以在很多关于CSS布局的文章中常提到"为什么使用表格排版是不明智的"这句话,可能是大家对他的理解有误,这里注意一点" 8gC(N3/E"  
n+GCL+Mo  
(%0X\zvu/  
  使用表格排版"是"不明智"的.指的是我们使用了很多年的,用表格来排版是不明智的,表格归根截底是一种显示"数据"的方式,大家可以想象一下EXCEL,表格就是起这个使用的,有的时候信息使用表格显示让我们能清晰易读,所以才使用表格,比如公司员工联系表,产品与型号对应表等. d c&Qi_W  
4 d]  
6%S>~L66  
  那么所谓表格大餐呢,其实意见上升到了一个层次,也就是说你如果能像专业市场分析公司那样,灵活使用表格来显示客户数据和调查数据等消息的时候,那才是真正利用了表格的优势. ^ioTd  
uFdSD  
iI&SI#; _  
  所以,关于那句使用以久的话,应该改为" =As'vt 0  
*C\4%l   
7 oZ-D~3  
  使用表格作为网页排版,布局页面元素是不合理的,表格是用来显示数据的"。 HTqikw5X  
z5'VsK:  
 7/7A  
  关于其它元素 Wq{'ZN  
1}jE?{V*  
BC$In!  
  我这里按我的使用经验,把XHTML标准中的一些元素,分为三大类: /v!H{Zw=c  
&\p :VF.  
%oor7 -l  
  第一类是我称之为辅助布局设计元素: g"Ii'JZ?  
wFqz.HoB  
mOXI"q]p  
  这里我指的是DIV,SPAN等,这类元素的主要功能是用来布局整个页面的,灵活使用这些元素的各种属性,可以让你的页面表现丰富多彩. *znCe(dd  
%Vt@7SwRJ  
t1Jz?Ix6%  
  第二类我称为结构化元素或叫信息元素 M3z7P.\G  
;? :,L  
>a4Bfnf"eI  
  这里指的是TABLE,UL,PRE,CODE类元素是一种信息显示与整理方式,比如TABLE很明显就是用来显示表格信息的,UL是用来显示列化信息的,当需要用表格或列表的时候,用这二种方式来显示是明智的。 *Mp<4B  
U'lmQrF!  
df J7Dhn  
  第三类指的是 这样的,完全是为了实现一些功能,如填上关键字的META keyword,还有做链接的A。 V)(pe #P  
w@:o:yLS  
)d.7xY7!  
  那么正确的符合标准的设计思路是: ;%k%AXw  
t#pY2!/T3  
Gc 8  
  使用DIV等布局元素来制作页面的设计布局,定位,色块,图片等 b6/:reH{  
VR:b1XWX  
41uS r 1  
  使用TABLE,UL等这样的元素来显示页面中需要展示数据 HdnSs0 /  
Ow^%n(Ezh  
LB{a&I LG  
  当然,DIV也起整理数据的作用,使用DIV的ID属性可以很方便的将一个DIV作为一个你名命的数据块。 8 Zj>|u  
}E1Eq  
50R+D0^mh  
  所以使用WEB标准来制作网站,实际是一个信息合理化整合的一个过程,什么地方该用什么元素还是照用不误,别把表格当布局工具就行。

简单生活
执著追求
别笑我浅溥,天真的以为用一腔真诚就能感动这个冷漠的世界。
也别说我幼稚,竟想用不长的人生去诠释繁杂的红尘。
然而除了真诚,我还能给你什么,的确我真的一无所有!

级别: 店掌柜
发帖
5692
铜板
103378
人品值
1520
贡献值
26
交易币
0
好评度
5373
信誉值
0
金币
0
所在楼道

只看该作者 11 发表于: 2006-07-26
盒模型bug的解决方法 Bpp9I;)c  
rFK *  
我们定义一个最基本的层: ./g#<  
7r;A wa  
'{u#:TTj  
kg@J.   
boxtest O71rLk;  
T6,lk1S'=  
div.boxtest{border:20px   solid #60A179;padding: 30px;background : #ffc;width : 400px;} 0ND7F  
O0l;Qi  
标准情况下,这个盒的宽度是:20+30+300+30+20=400px。 ixH7oWH#  
K*}j1A  
"nefRz%j+  
但是在IE5.0浏览器中,对盒模型的宽度解释有个bug,它认为300 px是整个盒的总宽度,内容的宽度变成:300-20-30-20-30=200px。 :OZhEBL&b  
U{}7:&As  
Z"^@B2v  
为了弥补这个bug,采用一个技巧:即增加一个IE5不能解释的声音属性"voice-family",读到这个定义时浏览器就不再继续阅读,认为宽就是400px,但而其他符合标准的浏览器会继续阅读,并执行第二个真实值300px。 enr mjA&3  
E<4}mSn)  
.KLuGb 3JJ  
t&uHn5  
content lKwcT!Q4  
>k jJq]A2  
div.content{border:20px solid #60A179;;padding:30px;background: #ffc;width :400px;voice-family :   "\"}\"";voice-family :inherit;width : 300px;} Y'~&%|9+T  
 "O 'I  
同样,在Opera7.0以前的浏览器也有这样的解析bug。但我们并不需要使用伪值,有更简单的办法解决这个问题: html>body .content { width :300; }

简单生活
执著追求
别笑我浅溥,天真的以为用一腔真诚就能感动这个冷漠的世界。
也别说我幼稚,竟想用不长的人生去诠释繁杂的红尘。
然而除了真诚,我还能给你什么,的确我真的一无所有!

级别: 经院小学
发帖
198
铜板
191
人品值
-98
贡献值
0
交易币
0
好评度
198
信誉值
0
金币
0
所在楼道
学一楼
只看该作者 12 发表于: 2012-04-13
好多啊,哈哈,谢谢您 F&~vD  
,m8*uCf  
;CZcY] ol  
X9j+$X \j  
jY.%~Y1y  
e- CW4x  
zE/(F;> FV  
J"MJVMo$T  
ZIl<y{  
8090 http://www.weiguan.cc/detail/29090.html 百度影音
描述
快速回复

您目前还是游客,请 登录注册
批量上传需要先选择文件,再选择上传
认证码:
验证问题:
3+5=?,请输入中文答案:八 正确答案:八