第6天:XHTML代码规范Posted by 徒步者
1.所有的标记都必须要有一个相应的结束标记
以前在HTML中,你可以打开许多标签,例如<p>和<li>而不一定写对应的</p>和</li>来关闭它们。但在XHTML中这是不合法的。XHTML要求有严谨的结构,所有标签必须关闭。如果是单独不成对的标签,在标签最后加一个"/"来关闭它。例如:
复制内容到剪贴板
代码:
<br /><img height="80" alt="网页设计师" src="../images/logo_w3cn_200x80.gif" width="200" />2.所有标签的元素和属性的名字都必须使用小写与HTML不一样,XHTML对大小写是敏感的,<title>和<TITLE>是不同的标签。XHTML要求所有的标签和属性的名字都必须使用小写。例如:<BODY>必须写成<body> 。大小写夹杂也是不被认可的,通常dreamweaver自动生成的属性名字"onMouseOver"也必须修改成"onmouseover"。
3.所有的XML标记都必须合理嵌套同样因为XHTML要求有严谨的结构,因此所有的嵌套都必须按顺序,以前我们这样写的代码:
复制内容到剪贴板
代码:
<p><b></p></b>必须修改为:
复制内容到剪贴板
代码:
<p><b></b></p>就是说,一层一层的嵌套必须是严格对称。
4.所有的属性必须用引号""括起来在HTML中,你可以不需要给属性值加引号,但是在XHTML中,它们必须被加引号。例如:
复制内容到剪贴板
代码:
<height=80>必须修改为:
复制内容到剪贴板
代码:
<height="80">特殊情况,你需要在属性值里使用双引号,你可以用",单引号可以使用',例如:
复制内容到剪贴板
代码:
<alt="say'hello'">5.把所有<和&特殊符号用编码表示
- 任何小于号(<),不是标签的一部分,都必须被编码为
& l t ;
- 任何大于号(>),不是标签的一部分,都必须被编码为
& g t ;
- 任何与号(&),不是实体的一部分的,都必须被编码为
& a m p;
注:以上字符之间无空格。
6.给所有属性赋一个值XHTML规定所有属性都必须有一个值,没有值的就重复本身。例如:
复制内容到剪贴板
代码:
<td nowrap><input type="checkbox" name="shirt" value="medium" checked>必须修改为:
复制内容到剪贴板
代码:
<td nowrap="nowrap"><input type="checkbox" name="shirt" value="medium" checked="checked">7.不要在注释内容中使“--”“--”只能发生在XHTML注释的开头和结束,也就是说,在内容中它们不再有效。例如下面的代码是无效的:
<!--这里是注释-----------这里是注释-->
用等号或者空格替换内部的虚线。
<!--这里是注释============这里是注释-->
以上这些规范有的看上去比较奇怪,但这一切都是为了使我们的代码有一个统一、唯一的标准,便于以后的数据再利用。
第7天:CSS入门Posted by 徒步者
1.基本语法规范分析一个典型CSS的语句:
复制内容到剪贴板
代码:
p {COLOR:#FF0000;BACKGROUND:#FFFFFF}- 其中"p"我们称为"选择器"(selectors),指明我们要给"p"定义样式;
- 样式声明写在一对大括号"{}"中;
- COLOR和BACKGROUND称为"属性"(property),不同属性之间用分号";"分隔;
- "#FF0000"和"#FFFFFF"是属性的值(value)。
2.颜色值颜色值可以用RGB值写,例如:
复制内容到剪贴板
代码:
color : rgb(255,0,0),也可以用十六进制写,就象上面例子
复制内容到剪贴板
代码:
color:#FF0000如果十六进制值是成对重复的可以简写,效果一样。例如

FF0000可以写成#F00。但如果不重复就不可以简写,例如#FC1A1B必须写满六位。
3.定义字体web标准推荐如下字体定义方法:
复制内容到剪贴板
代码:
body { font-family : "Lucida Grande", Verdana, Lucida, Arial, Helvetica, 宋体,sans-serif; }- 字体按照所列出的顺序选用。如果用户的计算机含有Lucida Grande字体,文档将被指定为Lucida Grande。没有的话,就被指定为Verdana字体,如果也没有Verdana,就指定为Lucida字体,依此类推,;
- Lucida Grande字体适合Mac OS X;
- Verdana字体适合所有的Windows系统;
- Lucida适合UNIX用户
- "宋体"适合中文简体用户;
- 如果所列出的字体都不能用,则默认的sans-serif字体能保证调用;
4.群选择器当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,
复制内容到剪贴板
代码:
p, td, li { font-size : 12px ; }5.派生选择器可以使用派生选择器给一个元素里的子元素定义样式,例如这样:
复制内容到剪贴板
代码:
li strong { font-style : italic; font-weight : normal;}就是给li下面的子元素strong定义一个斜体不加粗的样式。
6.id选择器用CSS布局主要用层"div"来实现,而div的样式通过"id选择器"来定义。例如我们首先定义一个层
复制内容到剪贴板
代码:
<div id="menubar"></div>然后在样式表里这样定义:
复制内容到剪贴板
代码:
#menubar {MARGIN: 0px;BACKGROUND: #FEFEFE;COLOR: #666;}其中"menubar"是你自己定义的id名称。注意在前面加"#"号。
id选择器也同样支持派生,例如:
复制内容到剪贴板
代码:
#menubar p { text-align : right; margin-top : 10px; }这个方法主要用来定义层和那些比较复杂,有多个派生的元素。
6.类别选择器在CSS里用一个点开头表示类别选择器定义,例如:
复制内容到剪贴板
代码:
.14px {color : #f60 ;font-size:14px ;}在页面中,用class="类别名"的方法调用:
复制内容到剪贴板
代码:
<span class="14px">14px大小的字体</span>这个方法比较简单灵活,可以随时根据页面需要新建和删除。
7.定义链接的样式CSS中用四个伪类来定义链接的样式,分别是:a:link、a:visited、a:hover和a : active,例如:
a:link{font-weight : bold ;text-decoration : none ;color : #c00 ;}a:visited {font-weight : bold ;text-decoration : none ;color : #c30 ;}a:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}a:active {font-weight : bold ;text-decoration : none ;color : #F90 ;}
以上语句分别定义了"链接、已访问过的链接、鼠标停在上方时、点下鼠标时"的样式。注意,必须按以上顺序写,否则显示可能和你预想的不一样。记住它们的顺序是“LVHA”。
CSS布局与传统表格(table)布局最大的区别在于:原来的定位都是采用表格,通过表格的间距或者用无色透明的GIF图片来控制文布局版块的间距;而现在则采用层(div)来定位,通过层的margin,padding,border等属性来控制版块的间距。
第8天:CSS布局入门Posted by 徒步者
1.定义DIV分析一个典型的定义div例子:
#sample{ MARGIN: 10px 10px 10px 10px;
PADDING:20px 10px 10px 20px;
BORDER-TOP: #CCC 2px solid;
BORDER-RIGHT: #CCC 2px solid;
BORDER-BOTTOM: #CCC 2px solid;
BORDER-LEFT: #CCC 2px solid;
BACKGROUND: url(images/bg_poem.jpg) #FEFEFE no-repeat right bottom;
COLOR: #666;
TEXT-ALIGN: center;
LINE-HEIGHT: 150%; WIDTH:60%; }
说明如下:
- 层的名称为sample,在页面中用<div id="sample">就可以调用这个样式。
- MARGIN是指层的边框以外留的空白,用于页边距或者与其它层制造一个间距。"10px 10px 10px 10px"分别代表"上右下左"(顺时针方向)四个边距,如果都一样,可以缩写成"MARGIN: 10px;"。如果边距为零,要写成"MARGIN: 0px;"。注意:当值是零时,除了RGB颜色值0%必须跟百分号,其他情况后面可以不跟单位"px"。MARGIN是透明元素,不能定义颜色。
- PADDING是指层的边框到层的内容之间的空白。和margin一样,分别指定上右下左边框到内容的距离。如果都一样,可以缩写成"PADDING:0px"。单独指定左边可以写成"
ADDING-LEFT: 0px;"。PADDING是透明元素,不能定义颜色。 - BORDER是指层的边框,"BORDER-RIGHT: #CCC 2px solid;"是定义层的右边框颜色为"#CCC",宽度为"2px",样式为"solid"直线。如果要虚线样式可以用"dotted"。
- BACKGROUND是定义层的背景。分2级定义,先定义图片背景,采用"url(../images/bg_logo.gif)"来指定背景图片路径;其次定义背景色"#FEFEFE"。"no-repeat"指背景图片不需要重复,如果需要横向重复用"repeat-x",纵向重复用"repeat-y",重复铺满整个背景用"repeat"。后面的"right bottom;"是指背景图片从右下角开始。如果没有背景图片可以只定义背景色BACKGROUND: #FEFEFE
- COLOR用于定义字体颜色,上一节已经介绍过。
- TEXT-ALIGN用来定义层中的内容排列方式,center居中,left居左,right居右。
- LINE-HEIGHT定义行高,150%是指高度为标准高度的150%,也可以写作:LINE-HEIGHT:1.5或者LINE-HEIGHT:1.5em,都是一样的意思。
- WIDTH是定义层的宽度,可以采用固定值,例如500px,也可以采用百分比,象这里的"60%"。要注意的是:这个宽度仅仅指你内容的宽度,不包含margin,border和padding。但在有些浏览器中不是这么定义的,需要你多试试。
2.CSS2盒模型自从1996年CSS1的推出,W3C组织就建议把所有网页上的对像都放在一个盒(box)中,设计师可以通过创建定义来控制这个盒的属性,这些对像包括段落、列表、标题、图片以及层<div>。盒模型主要定义四个区域:内容(content)、边框距(padding)、边界(border)和边距(margin)。上面我们讲的sample层就是一个典型的盒。对于初学者,经常会搞不清楚margin,background-color,background-image,padding,content,border之间的层次、关系和相互影响。这里提供一张盒模型的3D示意图,希望便于你的理解和记忆。
3.辅助图片一律用背景处理用XHTML+CSS布局,有一个技术一开始让你不习惯,应该说是一种思维方式与传统表格布局不一样,那就是:所有辅助图片都用背景来实现。类似这样:
BACKGROUND: url(images/bg_poem.jpg) #FEFEFE no-repeat right bottom;
尽管可以用<img>直接插在内容中,但这是不推荐的。这里的"辅助图片"是指那些不是作为页面要表达的内容的一部分,而仅仅用于修饰、间隔、提醒的图片。例如:相册中的图片、图片新闻中的图片,上面的3d盒模型图片都属于内容的一部分,它们可以用<img>元素直接插在页面里,而其它的类似logo,标题图片,列表前缀图片都必须采用背景方式或者其他CSS方式显示。
这样做的原因有2点:
- 将表现与结构彻底相分离,用CSS控制所有的外观表现,便于改版。
- 使页面更具有易用性,更有亲和力。例如:盲人使用屏幕阅读机,用背景技术实现的图片就不会被朗读出来。