frameset小结

之前的BQEGSR用到frameset,恩,当时时间太紧,没怎么仔细研究,就过去了,这次advantech又用到了,恩,还是没来得及研究,只是周五晚上突然想起来,就马上用了,今天又有修改到,所以临时搜索了下,刚好找到位博客园的兄弟讲到了,就给转贴过来了,呵呵,有点懒惰,不过有句话说的话,千古佳文一大抄么,呵呵,只是给自己留下点什么,所以良心上让自己过得去就好,嘿嘿

■ 框架标记

  <FRAMESET> <FRAME>
  <NOFRAMES>
  <IFRAME>

  欲明白本篇【HTML彻底剖析】之标记分类,请看 【标记一览】。
  也请先明白围堵标记与空标记的分别,请看 【HTML概念】。

 

■ 框架概念 :

  谓框架便是网页画面分成几个框窗,同时取得多个 URL。只需要 <FRAMESET> <FRAME> 即可,面所有框架标记需要放在一个总起的 html 档,这个档案只记录了该框架如何分割 ,不会显示任何资料,所以不必放入 <BODY> 标记,浏览这框架必须读取这档案 面不是其他框窗的档案。<FRAMESET> 是用来划分框窗,每一窗框由一个 <FRAME> 标 记所标示,<FRAME>必须在 <FRAMESET> 范围中使用。如下例:

  <frameset cols="50%,*"> <frame name="hello" src="up2u.html"> <frame name="hi" src="me2.html">
  </frameset>

  此例中 <FRAMESET> 把画面分成左右两相等部分,左便是显示 up2u.html,右边则会显示 me2.html 这档案,<FRAME> 标记所标示的框窗永远是按由上而下、由左至右的次序


<FRAME>
用法:      定义一个帧
开始/结束标识: 必须/非法
属性:      name="..."定义帧的名字
         scr="..."定义在帧中显示的内容的来源
         frameborder="..."定义帧之间的边界(0或1)
         margwidth="..."设置帧的边界和其中内容之间的间距
         margheight="..."设置帧的边界和其中内容之间的间距化
         noresize="..."使帧的尺寸不能变
         scrolling="..."设置滚动条的表示方式(auto, yes, no)
空:       不允许

<FRAMESET>...</FRAMESET>
用法:      定义在一个窗口中帧的布局
开始/结束标识: 必须/必须
属性:      rows="..."设定行的数目
         cols="..."设定列的数目
         onload="..."当载入文档时的内部事件触发器
         onunload="..."当卸载文档时的内部事件触发器
空:       不允许
注释:      FRAMESET可以嵌套

以上所述只是最简单的框架设定,若希望达到更合适的效果请加入或修改以下各参数。

  标记:<FRAMESET>
  例子:<frameset rows="90,*" frameborder="0" border=0 framespacing="2" border="2" bordercolor="#008000"></frameset>
  功用:宣告HTML文件为框架模式,并设定视窗如何分割。

  参数:

  • COLS="90,*"
    垂直切割画面(如分左右两个画面),接受整数值百分数* 则代表占用剩余的空间。数值的个数代表分成的视窗数目且以逗号分隔。例如 COLS="30,*,50%" 可以切成三个视窗,第一个视窗是 30 pixels 的宽度,为一绝对分割,第二个视窗是当分配完第一及第三个视窗后剩下的空间,第三个视窗则占整个视窗画面的 50% 宽度为一相对分割。你可自己调整数字
  • ROWS="120,*"
    这是横向切割,将画面上下分开,数值设定同上。 COLS 与 ROWS 两参数尽量不要放在同一个 <FRAMESET> 标记中,因 Netacape 偶然不能显示这类型的框架,尽量采用多重分割,如以上各例。
  • frameborder="0"
    设定框架的边框,其值只有 0 和 1 , 0 表示不要边框, 1 表示要显示边框。
  • border="0"
    设定框架的边框厚度,以 pixels 为单位。
  • bordercolor="#008000"
    设定框架的边框颜色。颜色值请参考【调色原理】。
  • framespacing="5"
    表示框架与框架间保留的空白的距离。

  标记:<FRAME>
  例子:<frame name="top" src="a.html" marginwidth="5" marginheight="5" scrolling="Auto" frameborder="0" noresize framespacing="6" bordercolor="#0000FF">
  功能:设定每一个框窗内的参数属性。
  参数:

  • SRC="a.html"
    设定此框窗中要显示的网页档案名称,每个框窗一定要对应一个网页档案。
  • NAME="top"
    设定这个框窗的名称,这样才能指定框架来作链接,必须但任意命名。
  • frameborder=0
    设定框架的边框,其值只有 0 和 1 , 0 表示不要边框, 1 表示要边框。
  • framespacing="6"
    表示框架与框架间的保留的空白的距离。
  • bordercolor="#008000"
    设定框架的边框颜色。
  • scrolling="Auto"
    设定是否要显示卷轴,YES 表示要显示卷轴,NO 表示无论如何都不要显示卷轴,AUTO 视情况而定。
  • noresize
    设定不让使用者可以改变这个框框的大小,如没有设定此参数,使用者可随意地拉动框架改变其大小。
  • marginhight=5
    表示框架高度部分边缘所保留的空间。
  • marginwidth=5
    表示框架宽度部分边缘所保留的空间。


说的也不是很全,我还要在补充下
这点很重要,当初我就是因为这个,找了好久才把滚动条给搞定,当时很郁闷
就是 <frameset></frameset>节点必须接在<head></head>节点之后,不能再有<body></body>节点了
下面的是我项目中用到的一段代码,直接贴过来,有些属性好像也没有起作用,就没仔细管它了

 1<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 2<html xmlns="http://www.w3.org/1999/xhtml" >
 3<head>
 4    <title>Advantech</title>
 5</head>
 6<frameset frameborder="0" framespacing="0" name="TotalFrameSet" rows="65px,100%,15px" align="middle">
 7    <frameset frameborder="0" framespacing="0" name="Top" cols="100%,18px" align="middle">
 8        <frame id="Header" name="Header" bordercolor="#FFFFFF" noresize src="Header.htm" frameborder="0" 
 9            scrolling="no" marginheight="0" marginwidth="0" >    
10        </frame>
11        <frame scrolling="no" width="18px" noresize>
12        </frame> 
13    </frameset>
14        <frame id="MainFrame" name="MainFrame" bordercolor="#FFFFFF" noresize src="Main.aspx" frameborder="0"
15            scrolling="yes" marginheight="0" marginwidth="0">    
16        </frame>
17    <frameset frameborder="0" framespacing="0" name="Bottom" cols="100%,18px" align="middle">
18        <frame id="Footer" name="Footer" bordercolor="#ffffff" noresize src="Footer.htm" frameborder="0"
19            scrolling="no" scrolling-y="yes" marginheight="0" marginwidth="0" >
20        </frame>
21        <frame scrolling="no" width="18px" noresize>
22        </frame> 
23    </frameset>
24</frameset>
25</html>
原文地址:https://www.cnblogs.com/forward/p/888061.html