UI

快速精通掌握FRAME的使用

  FRAME(框架)是Web上经常会看到的页面结构。使用可视Web开发工具(比如Dreamweaver或者Frontpage),虽然可以在WYSIWYG环境中通过简单的鼠标托拽完成FRAME的构建,但是要实现真正细致甚至强大的功能,仔细理解FRAME的代码结构至关重要!你将发现,FRAME原来是这样的亲切易用。

  创建基本的FRAMESET

  FRAMESET页面与普遍的Web页面有些不同。虽然仍旧以<html>和包含标题的<head>标记以及其他脚本开始,但是其内容仅仅是表示的各个页面的版式设计。因此,不再需要有<body>元素,只需要<frameset>标记。

  通过<frameset>标记的<rows>和<cols>属性,浏览器窗口被分割为一个个格子。<rows>和<cols>的设置值可以是固定的像素值,可以是总空间的百分比值,还可以是用*以及一个数字相乘表示的分割剩余空间的比例值。比如说:

cols=”80,20%,*” 分为3列,宽度分别为80像素,窗口宽度的20%,以及剩余宽度
rows=”25%,75%” 分为2列,宽度分别为窗口宽度的25%和75%
rows=”*,3*” 与上述第2个表示的一样,分为2列,但表示方法不同:第一列宽度为第二列的1/3

  在<frameset>和</frameset>之间,用多个<frame>标记表示每个分割区。col表示从左到右的列,row表示从上到下的行。每个<frame>有一个src属性,给出了这个FRAME的内容。它可以是浏览器能显示的任何一个合法URL,或者是另外一个FRAMESET。为预防递归现象,一个FRAME不能包含它本身所在的FRAMESET页面。要用name属性定义FRAME的名字,这样就可以在代码或者脚本程序中引用它。 请看一段基本的FRAMESET代码:

<html>
<head>
<title>Simple FRAMESET</title>
</head>
<frameset cols=”40%,60%” rows=”2*,*”>
<frame name=”TopLeft” src=”red.htm”>
<frame name=”TopRight” src=”green.htm”>
<frame name=”BotLeft” src=”blue.htm”>
<frame name=”BotRight” src=”white.htm”>
</frameset>
</html>
<frameset rows=”105,*”>
<frame name=”adbanner” src=”ad.html”>
<frameset cols=”40%,60%”>
<frame name=”left” src=”red.htm”>
<frameset rows=”*,*”>
<frame name=”top” src=”blue.htm”>
<frame name=”bottom” src=”white.htm”>
</frameset>
</frameset>
</frameset>

  FRAME间的链接

  一个FRAMESET结构的页面,新文档只转载进窗口的一部分中,而其他页面则保持静态不变。当用户点击FRAME中的链接时,新内容就在同一FRAME内打开。要让新内容在其他FRAME中打开,可以设置<a>标记的target属性值为那个FRAME的name值。

  而且,我们还可以设置打开目标为当前可见的任意一个FRAME,而不局限于本身的FRAMESET。目标可能是一个嵌套的FRAMESET中的FRAME,也可能是其他窗口中的FRAME。但是如果目标FRAME不存在,就会产生一个带有目标FRAME名字的新窗口。

  下面举个例子说明一下,假设有一个简单含2-FRAME的FRAMESET,文件名叫做home.html,代码如下:

<html>
<head><title>FrommCo home page</title></head>
<frameset cols=”115,*”>
<frame src=”menu.htm”>
<frame name=”content” src=”main.htm”>
</frameset>
</html>

  文件menu.htm在左边的FRAME中,其中有一系列链接,点击它们后新内容将在右边的叫做content的FRAME中打开。下面是menu.html的代码:

<html><head></head>
<body><p>

<img src=”Images/tmp_logo.gif” alt=”FrommCo”><p>
<a href=”main.htm” target=”content”>Main page</a><p>
<a href=”mission.htm” target=”content”>Our mission</a><p>
<a href=”staff.htm” target=”content”>Our staff</a><p>
<a href=”splash.htm” target=”_parent”>FrommCo splash page</a>
</body></html>

  请注意最后一个链接中target的定义为_parent,这属于4个特殊的保留值。它们是:
_parent:在当前FRAMESET位置显示新href。
_top:在当前整个窗口位置显示新href,比如本身FRAMESET位于另一个FRAMESET中。
_self:强制在当前FRAME中显示新href。
_blank:在新窗口中显示href。
  表示客户端图形地图的<area>标记同样可以应用target属性,比如:

  <area shape=circle coords=”75,75,50″ href=”main.htm” target=”content” alt=”Main page”>

  还有一种经常的情况是:Web页面中的大部分或者全部链接都要求在一个特别的FRAME中打开。这时,可以在页面的<head>代码区使用<base>标记设置默认的target,然后再分别定义特殊链接的target值。

  修饰FRAME

  FRAMESET不仅在宽度、高度等方面具有可控制的数值,在美观方面也同样可以精确设置。

  默认情况下,FRAMESET的FRAME间有一个凸起的边沿,表示分割效果。如果不喜欢这个,想营造“无缝连接”的效果,可以在<frame>标记中设置FRAMEborder=0来消除它。在3.0及高版本的Navigator和Internet Explorer中,如果在<frameset>标记中设置FRAMEborder=0,那么除了设置为FRAMEborder=1的FRAME外,

分类: UI

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理

相关文章

开始在上面输入您的搜索词,然后按回车进行搜索。按ESC取消。

返回顶部