iframe怎么读?iframe嵌入页面
大家好,关于iframe怎么读很多朋友都还不太明白,今天小编就来为大家分享关于iframe嵌入页面的知识,希望对各位有所帮助!
iframe怎么发音呢啊衣弗瑞姆还是艾弗瑞姆
iframe的发音为[aifreim]。以下是关于iframe发音的详细说明:
没有标准发音:iframe并非一个英语单词,而是HTML语言中的一个关键词。因此,没有特定的组织或机构为其规定标准发音。业内发音习惯:尽管没有标准发音,但在HTML和Web开发的业内人士中,iframe一般读作[aifreim]。发音建议:根据业内人士的习惯,建议将iframe读作[aifreim],即你提到的“艾弗瑞姆”。因此,在提到iframe时,可以读作[aifreim],以避免产生误解或混淆。
html中框架(frame)的详细使用方法
框架概念:
所谓框架便是网页画面分成几个框窗,同时取得多个 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>标记所标示的框窗永远是按由上而下、由左至右的次序。
<FRAMESET><FRAME>:
<FRAMESET>称框架标记,用以宣告HTML文件为框架模式,并设定视窗如何分割。
<FRAME>则只是设定某一个框窗内的参数属性。
<FRAMESET>参数设定:
例子:<frameset rows="90,*" frameborder="0" border=0 framespacing="2" bordercolor="#008000">
COLS="90,*"
垂直切割画面(如分左右两个画面),接受整数值、百分数,*则代表占用馀下空间。数值的个数代表分成的视窗数目且以逗号分隔。例如 COLS="30,*,50%"可以切成三个视窗,第一个视窗是 30 pixels的宽度,为一绝对分割,第二个视窗是当分配完第一及第三个视窗后剩下的空间,第三个视窗则占整个画面的 50%宽度为一相对分割。您可自己调整数字。
ROWS="120,*"
就是横向切割,将画面上下分开,数值设定同上。唯 COLS与 ROWS两参数尽量不要同在一个<FRAMESET>标记中,因 Netacape偶然不能显示这类形的框架,尽采用多重分割。
frameborder="0"
设定框架的边框,其值只有 0和 1, 0表示不要边框, 1表示要显示边框。(避免使用 yes或 no)
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表示要显示边框。(避免使用 yes或 no)
framespacing="6"
表示框架与框架间的保留空白的距离。
bordercolor="#008000"
设定框架的边框颜色。颜色值请参考【HTML剖析】。
scrolling="Auto"
设定是否要显示卷轴,YES表示要显示卷轴,NO表示无论如何都不要显示, AUTO是视情况显示。
noresize
设定不让使用者可以改变这个框框的大小,亦没有设定此参数,使用者可以很随意地拉动框架,改变其大小。
marginhight=5
表示框架高度部份边缘所保留的空间。
marginwidth=5
表示框架宽度部份边缘所保留的空间。
<NOFRAMES>:
当别人使用的浏览器太旧,不支援框架这个功能时,他看到的将会是一片空白。为了避免这种情况,可使用<NOFRAMES>这个标记,当使用者的浏览器看不到框架时,他就会看到<NOFRAMES>与</NOFRAMES>之间的内容,而不是一片空白。这些内容可以是提醒浏览转用新的浏览器的字句,甚至是一个没有框架的网页或能自动切换至没有框架的版本亦可。
应用方法:
在<frameset>标记范围加入</NOFRAMES>标记,以下是一个例子:
<frameset rows="80,*">
<noframes>
<body>
很抱歉,馈下使用的浏览器不支援框架功能,请转用新的浏览器。
</body>
</noframes>
<frame name="top" src="a.html">
<frame name="bottom" src="b.html">
</frameset>
若浏览器支援框架,那堋它不会理会<noframes>中的东西,但若浏览器不支援框架,由於不认识所有框架标记,不明的标记会被略过,标记包围的东西便被解读出来,所以放在<noframes>范围内的文字会被显示。
<IFRAME>:
这标记只适用於 IE。它的作用是在一页网页中间插入一个框窗以显示另一个文件。它是一个围堵标记,但围著的字句只有在浏览器不支援 iframe标记时才会显示,如<noframes>一样,可以放些提醒字句之类。通常 iframe配合一个辨认浏览器的 Java Script会较好,若 JavaScript认出该浏览器并非 Internet Explorer便会切换至另一版本。
<iframe>的参数设定如下:
例子:<iframe src="iframe.html" name="test" align="MIDDLE" width="300" height="100" marginwidth="1" marginheight="1" frameborder="1" scrolling="Yes">
src="iframe.html"
欲显示於此框窗的文件来源除档案名称,必要加上相对或绝对路径。
name="test"
此框窗名称,这是连结标记的 target参数所要的,
align="MIDDLE"
可选值为 left, right, top, middle, bottom,作用不大
width="300" height="100"
框窗的宽及长,以 pixels为单位。
marginwidth="1" marginheight="1"
该插入的文件与框边所保留的空间。
frameborder="1"
使用 1表示显示边框, 0则不显示。(可以是 yes或 no)
scrolling="Yes"
使用 Yes表示容许卷动(内定), No则不容许卷动。
例子:原始码
<center><iframe src="" name="test" align="MIDDLE" width="300" height="100" marginwidth="5" marginheight="5" frameborder="1">
很抱歉,馈下使用的浏览器并不支援 IFrame,不能正常浏览我的网页。</iframe>
</center>
frameset参数传递问题
左边的条件参数如何传,右边才能接收
--------------------------------------------------------------------------------
对三个帧分别命名为:left.asp(显示查询条件的页面,其中帧名为:left),top.asp,main.asp(显示查询结果的页面,其中帧名为:main)
如:
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>search</title>
</head>
<frameset rows="80,*" frameborder="NO" border="0" framespacing="0">
<frame src="top.asp" name="top" scrolling="NO" noresize>
<frameset cols="80,*" frameborder="NO" border="0" framespacing="0">
<frame src="left.asp" name="left" scrolling="NO" noresize>
<frame src="main.asp" name="main">
</frameset>
</frameset>
<noframes><body>
</body></noframes>
</html>
在left的表单中写成:
<form name="form1" method="post" action="main.asp" target="main">
......//你自己设计吧。
</form>
这样就可以你的查询条件传给main.asp中了!
怎么让iframe自适应高度
什么是自适应高度吧。所谓iframe自适应高度,就是,基于界面美观和交互的考虑,隐藏了iframe的border和scrollbar,让人看不出它是个iframe。如果iframe始终调用同一个固定高度的页面,我们直接写死iframe高度就可以了。而如果iframe要切换页面,或者被包含页面要做DOM动态操作,这时候,就需要程序去同步iframe高度和被包含页的实际高度了。
顺便说下,iframe在迫不得已的时候才去用,它会给前端开发带来太多的麻烦。
传统做法大致有两个:
方法一,在每个被包含页在本身内容加载完毕之后,执行JS取得本页面的高度,然后去同步父页面的iframe高度。
方法二,在主页面iframe的onload事件中执行JS,去取得被包含页的高度内容,然后去同步高度。
在代码维护角度考虑,方法二是优于方法一的,因为方法一,每个被包含页都要去引入一段相同的代码来做这个事情,创建了好多副本。
如果只考虑FX和IE,并且,iframe里面内容也不进行DOM操作,那仍然可以用最简单最方便的传统处理方式:
<iframe id="frame_content" src="iframe_b.html" scrolling="no" frameborder="0" onload="this.height=this.contentWindow.document.documentElement.scrollHeight"></iframe>
两个方法都只处理了静的东西,就是只在内容加载的时候执行,如果JS去操作DOM引起的高度变化,都不太方便。
如果在主窗口做一个Interval,不停的来获取被包含页的高度,然后做同步,是不是即方便,又解决了JS操作DOM的问题了呢?答案是肯定的。
Demo页面:主页面 iframe_a.html,被包含页面 iframe_b.htm和 iframe_c.html
主页面代码示例:
<iframe id="frame_content" src="iframe_b.html" scrolling="no" frameborder="0"></iframe><script type="text/javascript">
function reinitIframe(){
var iframe= document.getElementById("frame_content");
try{
iframe.height= iframe.contentWindow.document.documentElement.scrollHeight;
}catch(ex){}
}
window.setInterval("reinitIframe()", 200);
</script>
一直执行,效率会不会有问题?
我做了测试,同时开5个窗口(IE6、IE7、FF、Opera、Safari)执行这个代码,不会对CPU有什么影响,甚至调整到2ms,也没影响(基本维持在0%占用率)。
下面谈谈各浏览器的兼容性问题,如何获取到正确的高度,主要是对body.scrollHeight和documentElement.scrollHeight两个值得比较。注意本文用的是这个doctype,不同的doctype应该不会影响结果,但是假如你的页面没有申明doctype,那还是先去加一个吧。
<!DOCTYPE HTML PUBLIC"
在主页面追加以下测试代码,以输出这两个值,代码示例:
<div><button onclick="checkHeight()">Check Height</button></div><script type="text/javascript">
function checkHeight(){
var iframe= document.getElementById("frame_content");
var bHeight= iframe.contentWindow.document.body.scrollHeight;
var dHeight= iframe.contentWindow.document.documentElement.scrollHeight;
alert("bHeight:"+ bHeight+", dHeight:"+ dHeight);
}
</script>
被加载页面,可以切换一个绝对定位的层,来使页面高度动态改变。如果层展开,则会撑高页面高度。代码示例:
<div><button onclick="toggleOverlay()">Toggle Overlay</button>
</div>
<div style="height:160px;position:relative">
<div id="overlay" style="position:absolute;width:280px;height:280px;display:none;"></div>
</div>
<script type="text/javascript">
function toggleOverlay(){
var overlay= document.getElementById('overlay');
overlay.style.display=(overlay.style.display=='none')?'block':'none';
}
</script>
下面列出以上代码在各浏览器的测试值:
(bHeight= body.scrollHeight, dHeight= documentElement.scrollHeight,红色=错误值,绿色=正确值)
/
层隐藏时
层展开时
bHeight
dHeight
bHeight
dHeight
IE6 184 184 184 303
IE7 184 184 184 303
FF 184 184 184 303
Opera 181 181 300 300
Safari 184 184 303 184
暂且无视Opera比别人少3像素的问题…可以看出,如果没有绝对定位的东西,两个值是相等的,取哪个都无所谓。
但是如果有,那么各个浏览器的表现不太相同,单取哪个值都不对。但可以找到了一条规律,那就是取两个值得最大值可以兼容各浏览器。所以我们的主页面代码就要改造成这样了:
function reinitIframe(){var iframe= document.getElementById("frame_content");
try{
var bHeight= iframe.contentWindow.document.body.scrollHeight;
var dHeight= iframe.contentWindow.document.documentElement.scrollHeight;
var height= Math.max(bHeight, dHeight);
iframe.height= height;
}catch(ex){}
}
window.setInterval("reinitIframe()", 200);
这样子,基本解决了兼容性问题。顺便说下,不光绝对定位的层会影响到值,float也会导致两个值的差异。
如果你演示Demo后,会发现,除了IE,其他浏览器中,当层展开后再隐藏,取到的高度值还是维持在展开的高度303,而非隐藏回去的真正值184,就是说长高了之后缩不回去了。这个现象在不同被包含页面之间做切换也会发生,当从高的页面切换到矮页面的时候,取到的高度还是那个高的值。
可以归纳为,当iframe窗体高度高于文档实际高度的时候,高度取的是窗体高度,而当窗体高度低于实际文档高度时,取的是文档实际高度。因此,要想办法在同步高度之前把高度设置到一个比实际文档低的值。所以,在iframe的添加 onload=”this.height=100″,让页面加载的时候先缩到足够矮,然后再同步到一样的高度。
这个值,在实际应用中决定,足够矮但又不能太矮,否则在FF等浏览器里会有很明显的闪烁。DOM操作的时候主页面无法监听到,只能DOM操作完了之后把高度变小了。
在我的一个实际项目中,在成本和收益之间权衡,我并没有做这个事情,因为每个DOM函数中都要插入这个代码,代价太高,其实层缩回去不缩掉也不是那么致命。包括Demo里,也没有去做这个事情。如果读者有更好的方法,请告诉我。
这是最终的主页面的代码:
<iframe id="frame_content" src="iframe_b.html" scrolling="no" frameborder="0" onload="this.height=100"></iframe>
<script type="text/javascript">
function reinitIframe(){
var iframe= document.getElementById("frame_content");
try{
var bHeight= iframe.contentWindow.document.body.scrollHeight;
var dHeight= iframe.contentWindow.document.documentElement.scrollHeight;
var height= Math.max(bHeight, dHeight);
iframe.height= height;
}catch(ex){}
}
window.setInterval("reinitIframe()", 200);
</script>
附Demo页面:主页面 iframe_a.html,被包含页面 iframe_b.htm和 iframe_c.html
好了,文章到这里就结束啦,如果本次分享的iframe怎么读和iframe嵌入页面问题对您有所帮助,还望关注下本站哦!