[转载]Frame框架在Html中的应用详解

导读:
  FRAME(框架)是Web上经常会看到的页面结构。使用可视Web开发工具(比如Dreamweaver或者Frontpage),虽然可以在WYSIWYG环境中通过简单的鼠标托拽完成FRAME的构建,但是要实现真正细致甚至强大的功能,仔细理解FRAME的代码结构至关重要!你将发现,FRAME原来是这样的亲切易用。
   创建基本的FRAMESET:
  FRAMESET页面与普遍的Web页面有些不同。虽然仍旧以和包含标题的标记以及其他脚本开始,但是其内容仅仅是表示的各个页面的版式设计。因此,不再需要有元素,只需要标记。
  通过标记的 和 属性,浏览器窗口被分割为一个个格子。 和 的设置值可以是固定的像素值,可以是总空间的百分比值,还可以是用*以及一个数字相乘表示的分割剩余空间的比例值。比如说:
  cols="80,20%,*" 分为3列,宽度分别为80像素,窗口宽度的20%,以及剩余宽度
  rows="25%,75%" 分为2行,宽度分别为窗口宽度的25%和75%
  rows="*,3*" 与上述第2个表示的一样,分为2行,但表示方法不同:第一列宽度为第二行的1/3
  在和之间,用多个标记表示每个分割区。col表示从左到右的列,row表示从上到下的行。每个有一个src属性,给出了这个FRAME的内容。它可以是浏览器能显示的任何一个合法URL,或者是另外一个FRAMESET。为预防递归现象,一个FRAME不能包含它本身所在的FRAMESET页面。要用name属性定义FRAME的名字,这样就可以在代码或者脚本程序中引用它。 请看一段基本的FRAMESET代码:
  
  
   Simple FRAMESET
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
   FRAME间的链接:
  一个FRAMESET结构的页面,新文档只转载进窗口的一部分中,而其他页面则保持静态不变。当用户点击FRAME中的链接时,新内容就在同一FRAME内打开。要让新内容在其他FRAME中打开,可以设置 标记的target属性值为那个FRAME的name值。
  而且,我们还可以设置打开目标为当前可见的任意一个FRAME,而不局限于本身的FRAMESET。目标可能是一个嵌套的FRAMESET中的FRAME,也可能是其他窗口中的FRAME。但是如果目标FRAME不存在,就会产生一个带有目标FRAME名字的新窗口。
  下面举个例子说明一下,假设有一个简单含2-FRAME的FRAMESET,文件名叫做home.html,代码如下:
  
  FrommCo home page
  
  
  
  
  
  文件menu.htm在左边的FRAME中,其中有一系列链接,点击它们后新内容将在右边的叫做content的FRAME中打开。下面是menu.html的代码:
  
  



  FrommCo


  Main page


  Our mission


  Our staff


  FrommCo splash page
  
  请注意最后一个链接中target的定义为_parent,这属于4个特殊的保留值。它们是:
  _parent:在当前FRAMESET位置显示新href。
  _top:在当前整个窗口位置显示新href,比如本身FRAMESET位于另一个FRAMESET中。
  _self:强制在当前FRAME中显示新href。
  _blank:在新窗口中显示href。
  表示客户端图形地图的标记同样可以应用target属性,比如:
  Main page
  还有一种经常的情况是:Web页面中的大部分或者全部链接都要求在一个特别的FRAME中打开。这时,可以在页面的代码区使用标记设置默认的target,然后再分别定义特殊链接的target值。
  修饰FRAME:
  FRAMESET不仅在宽度、高度等方面具有可控制的数值,在美观方面也同样可以精确设置。
  默认情况下,FRAMESET的FRAME间有一个凸起的边沿,表示分割效果。如果不喜欢这个,想营造“无缝连接”的效果,可以在标记中设置FRAMEborder=0来消除它。在3.0及高版本的Navigator和Internet Explorer中,如果在标记中设置FRAMEborder=0,那么除了设置为FRAMEborder=1的FRAME外,所有其他FRAME的边沿都将消失。
  虽然设置了FRAMEborder=0,有些浏览器仍旧会在FRAME间保留一些边沿的颜色痕迹。这时,可以在标记中添加FRAMEspacing=0(对Internet Explorer)或者border=0(对Navigator和Opera)实现真正的无缝连接。
  请看下面的代码是如何使用这些属性的:
  
  FrommCo home page
  
  
  
  
  
  上面的代码中有2个新的属性:noresize表示锁住FRAME而不允许使用鼠标改变大小,scrolling=no表示屏蔽FRAME的滚动条,scrolling=yes表示允许,scrolling=auto表示根据显示内容需要自动显示滚动条。
  浮动FRAME:
  浮动FRAME是HTML4.0规范中的一个定义,目前的浏览器都支持它。
  不象FRAMESET表示的分割区样子,一个浮动FRAME作为一个内置对象存在于Web页面上,其样式就象一个页面上的一个图形或者一个applet。浮动FRAME使用

  Show one.htm


  Show two.htm


  Bring back start.htm
  注意,对应支持间的内容都将忽略。反之,其中的内容将显示出来,这可以用作解释当前浏览器不支持
  See grot.htm
  带有浮动FRAME的Web页面是FRAME文档的parent窗口,因此,多个浮动FRAME仍然可以通过parent.FRAME数组去访问每一个FRAME。
  预防脚本编程错误:
  尽管FRAME是HTML的一个稳定规范说明,但DOM模型只把它们当做HTML元素而不是窗口,因此围绕FRAME的脚本编程并不是能很周全地定义。这个不足导致了当装载FRAME时会发生一些脚本执行方面的冲突。
  立即修改FRAME内容的脚本经常会产生错误。原因在于:浏览器通常是先执行脚本命令,然后在按照src所示装入页面内容。
  解决方法很直接,就是判断FRAME内容是否装载完毕。有一个好的处理技巧是以HTML页面开始所有的FRAME,由它象主FRAMESET报告装载请看。比如说,有一个FRAMESET页面,要等装载完所有的FRAME后才能执行函数goToIt(),那么就将下面的JavaScript程序段放进FRAMESET文档中:
  countDown=FRAMEs.length;
  function soundOff(){
  countDown--;
  if (countDown==0){
  goToIt();}
  }
  然后,在每个FRAME页面的标记中设置上onLoad="parent.soundOff()"。当FRAME页面装载并执行soundOFF()后,等到countDown 为0时,就表示FRAME完全装载完毕。
  总结:
  FRAME是双刃剑,使用不好会造成混乱的站点结构和外观,使用得当将大大方便用户的操作方式以及形成清晰的页面风格。相信你看完本文后,会对FRAME有了更亲切的认识。

本文转自
http://hi.baidu.com/longaohun/blog/item/0c6ebb439e72441072f05d5c.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值