日期:2013-10-26 浏览次数:20828 次
如果只是由于浏览者改变了浏览器的设置,或者由于浏览器不兼容,使本人精心制造的网页变得“面目全非”,那多令人沮丧!下面我们以网页爱好者的常用工具Dreamweaver(以下简称DW)为例,列出几个网页制造初学者较常见的网页规划问题以及处理方法,希望对初学者们有所协助。
一、消弭任意缩放浏览器窗口对网页的影响
一番辛劳做出来的网页,在全屏形状下浏览一切正常。但在改变浏览窗口大小之后,网页就变得"不堪入目"了,这是个很值得留意的问题。
问题的本源还得从网页的规划说起,在DW中,网页内容的定位普通是通过表格来实现的,处理表格的问题也就成功了大半。
大家应该留意到,在DW中表格属性面板的高宽设定选择上提供了两种不同类型:百分比和像素值。百分比的使用将会产生前面说到的那个毛病。这里所说的百分比是指表格的高或宽设置为上层标记所占区域高或宽的百分比,如在一个表格单元的宽度是600,在它里面嵌入了另外一个表格,表格宽度占表格单元的50%,则这个表格的宽度为300,依此类推,如果在一个表格不是嵌于另一个表格单元中,则其百分比是绝对于当时窗口的宽度的。IE浏览器中,随便改动主页窗口的大小时,表格的内容也随之错位、变形,就是由于表格的百分比也要随着窗口的大小而改变成相应的百分比宽度。
自然,处理这个问题的办法就是将表格宽度设置成固定宽度(也就是像素值)。另外如果外层表格已做好固定宽度设置,内层表格也可以适当使用百分比设置。清楚这个准绳当前,如果出现类似的问题大家也知道怎样处理。
二、让网页居中
说到了窗口大小就会顺着路子想到分辨率的问题,在800×600分辨率下制造的网页在1024×768分辨率的机器上打开,整个网页就会跑到左边;1024×768分辨率的网页在800×600分辨率的机器上有时也会变得"不堪入目"。两种分辨率各做一个吧?做起来费时,看起来也费劲。怎样办呢?
如今大多数网民都还在用800*600的分辨率,所以我们普通可以以此分辨率为主,要想让网页在1024*768时居中,只需在网页原代码的<body>后紧加一句<center>,</body>前加一句</center>就OK了。不过有几个问题这是要留意一下,第一个就是上面说到的百分比的问题,表格、单元格的宽度单位最好要使用像素单位,而不要用百分比。例如width=770。如果你的表格宽度设的是百分比,那么使用大于800×600的像素时,网页就会拉宽,这样网页可能会变形。在<body>中加入leftmargin=0,即<body leftmargin=0>这种情况下,800×600支持的表格宽度为780像素时不会出现滚动条。还有一点要留意的是不能用DW中的层来定位。
<html>
<head></head>
<body topmargin=0 leftmargin=0>
<center>
<table cellspacing cellpadding width=760><tr><td></td></tr></table>
</center>
</body>
</html>
三、定义固定大小的文字
大家都知道,在IE浏览器的功用设置中,有一个可以自在设置窗口内容字体大小的功用,这样由于不同访问者的设置习惯不同,呈如今他们面前的网页有时也会不不相反。比如你可能本来设计时用的是2号字体,结果由于用户对浏览器的额外设定,变的更大了,这时你的网页也可能变得"不堪入目"。虽然不是你的错,但客户是上帝。
如果使用了网页中的CSS款式表技术,就不会出现上述情况了。使用快捷键"Shift+F11"打开款式表"CSS Style"编辑器,在窗口中单击鼠标右键执行"New CSS Style..."命令新建一个款式表,然后在给出的列表中选择"类型"选项,定义文字属性参数(普通文字的大小选择12px较为适宜)。完成后选择网页编辑窗中的文本,单击新的款式表名称,可以看到选中的文本发生了变化。预览时试试定义的文本字体尺寸还会不会随浏览器的选择字体大小而改变。
四、让网页顺应不同的浏览器
浏览器的格式如今是两分天下,一分是IE,另一分是NetScape,在国内Ie有绝对的占有率,在这种情况下我们设计的网页只需兼容它就行了,但NetScape在国外还是有很多人使用,毕竟它是浏览器的元老。
虽然没有办法做出让所有浏览器都兼容的网站,但只需留意以下几点,做出来的网页在各个浏览器都中能达到比较好的显示效果:
不要混合使用层和表格排版,如果是父子关系,如层中表格,不在此准绳范围内。
内联式的 CSS 在 Netscape Navigator 中经常会出现问题,使用链式或内嵌式。
有时需求在空层插入表格或者通明图片,以保证在 Netscape Navigator 里的效果。
对于只要几个像素宽度或高度的层,改用图片来实现。
避免使用 W3C 组织不推荐的排版属性,用 CSS 代替。