一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

Iframe 自適應(yīng)高度并實(shí)時(shí)監(jiān)控高度變化的js代碼

google N次 + 百度M次 + 試驗(yàn)了1605次之后(聽說農(nóng)藥1605就是實(shí)驗(yàn)了這么多次后出來的),得出下面成果,在IE7及Firefox3里試了下還能湊合著用用!
1、首先給出個(gè)Iframe。
復(fù)制代碼 代碼如下:
<iframe id="ifrm"
marginheight="0"
marginwidth="0"
height="100"
width="1000"
frameborder="0"
scrolling="no"
src="xxxxx.html">
</iframe>

2、然后看看怎么獲取Iframe中的頁面的高度。
其實(shí)最麻煩的就是怎么讓獲取的高度準(zhǔn)確,不同的方式不同的瀏覽器中獲取到的值都會(huì)不一樣!暈啊~~。參考了多方意見得出以下Javascript函數(shù)(doc參數(shù)為window.document對(duì)象):
復(fù)制代碼 代碼如下:
function getDocHeight(doc)
{
//在IE中doc.body.scrollHeight的可信度最高
//在Firefox中,doc.height就可以了
var docHei = 0;
var scrollHei;//scrollHeight
var offsetHei;//offsetHeight,包含了邊框的高度
if (doc.height)
{
//Firefox支持此屬性,IE不支持
docHei = doc.height;
}
else if (doc.body)
{
//在IE中,只有body.scrollHeight是與當(dāng)前頁面的高度一致的,
//其他的跳轉(zhuǎn)幾次后就會(huì)變的混亂,不知道是依照什么取的值!
//似乎跟包含它的窗口的大小變化有關(guān)
if(doc.body.offsetHeight) docHei = offsetHei = doc.body.offsetHeight;
if(doc.body.scrollHeight) docHei = scrollHei = doc.body.scrollHeight;
}
else if(doc.documentElement)
{
if(doc.documentElement.offsetHeight) docHei = offsetHei = doc.documentElement.offsetHeight;
if(doc.documentElement.scrollHeight) docHei = scrollHei = doc.documentElement.scrollHeight;
}
/*
docHei = Math.max(scrollHei,offsetHei);//取最大的值,某些情況下可能與實(shí)際頁面高度不符!
*/
return docHei;
}

3、最后修改Iframe的高度,并用一個(gè)定時(shí)器來不間斷檢查它包含的頁面的高度變化。
復(fù)制代碼 代碼如下:
function doReSize()
{
var iframeWin = window.frames['ifrm'];
var iframeEl = window.document.getElementById? window.document.getElementById('ifrm'): document.all? document.all['ifrm']: null;
if ( iframeEl && iframeWin )
{
var docHei = getDocHeight(iframeWin.document);
if (docHei != iframeEl.style.height) iframeEl.style.height = docHei + 'px';
}
else if(iframeEl)
{
var docHei = getDocHeight(iframeEl.contentDocument);
if (docHei != iframeEl.style.height) iframeEl.style.height = docHei + 'px';
}
}
function runResizeTask()
{
doReSize();
setTimeout("runResizeTask()",500);//每隔半秒執(zhí)行一次
}
runResizeTask();

在這里就沒有去考慮被包含的頁面中是否有折疊、隱藏/展現(xiàn)的情況了!
完整js代碼
復(fù)制代碼 代碼如下:
<script language="Javascript" type="text/Javascript">
function getDocHeight(doc){
//在IE中doc.body.scrollHeight的可信度最高
//在Firefox中,doc.height就可以了
var docHei = 0;
var scrollHei;//scrollHeight
var offsetHei;//offsetHeight,包含了邊框的高度

if (doc.height){
//Firefox支持此屬性,IE不支持
docHei = doc.height;
}
else if (doc.body){
//在IE中,只有body.scrollHeight是與當(dāng)前頁面的高度一致的,
//其他的跳轉(zhuǎn)幾次后就會(huì)變的混亂,不知道是依照什么取的值!
//似乎跟包含它的窗口的大小變化有關(guān)
if(doc.body.offsetHeight) docHei = offsetHei = doc.body.offsetHeight;
if(doc.body.scrollHeight) docHei = scrollHei = doc.body.scrollHeight;
}
else if(doc.documentElement){
if(doc.documentElement.offsetHeight) docHei = offsetHei = doc.documentElement.offsetHeight;
if(doc.documentElement.scrollHeight) docHei = scrollHei = doc.documentElement.scrollHeight;
}
/*
docHei = Math.max(scrollHei,offsetHei);//取最大的值,某些情況下可能與實(shí)際頁面高度不符!
*/
return docHei;
}
function doReSize(){
var iframeWin = window.frames['Main'];
var iframeEl = window.document.getElementById? window.document.getElementById('Main'): document.all? document.all['Main']: null;
if ( iframeEl && iframeWin ){
var docHei = getDocHeight(iframeWin.document);
if (docHei != iframeEl.style.height) iframeEl.style.height = docHei + 'px';
}
else if(iframeEl){
var docHei = getDocHeight(iframeEl.contentDocument);
if (docHei != iframeEl.style.height) iframeEl.style.height = docHei + 'px';
}
}

function runResizeTask(){
doReSize();
setTimeout("runResizeTask()",1000);//每隔1秒執(zhí)行一次
}
runResizeTask();
</script>

JavaScript技術(shù)Iframe 自適應(yīng)高度并實(shí)時(shí)監(jiān)控高度變化的js代碼,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 午夜毛片福利 | 黄色影片在线免费观看 | 国产一区二区三区毛片 | 久久久久青草大香线综合精品 | 米奇精品一区二区三区 | 精品免费一区二区三区 | 亚洲午夜精品久久久久久成年 | 都市激情中文字幕 | 九一国产精品视频 | 97精品在线视频 | 欧美三级精品 | 一级做a爰在线就看 | 亚洲成a | 亚洲综合色婷婷久久 | 日本韩国欧美一区 | 久久美女精品 | 视频黄色在线 | 亚洲国产激情在线一区 | 91免费观看视频 | 六月激情网 | 四虎影视国产永久免费 | 久久亚洲成a人片 | 久久久久久88色愉愉 | 久久亚洲精品无码观看不卡 | 天天更新天天久久久更新影院 | 人人做人人爽人人爱影视 | 狠狠色噜噜狠狠狠97影音先锋 | 中文字幕亚洲一区二区v@在线 | 亚洲色四在线视频观看 | 久久国产精品ww | 亚洲射图 | 精品中文字幕一区二区三区四区 | www.日本高清| 婷婷亚洲视频 | 国产无套在线观看视频 | 黑人一级毛片 | 久久久中文字幕 | 亚洲三级色 | 男人女人无遮掩免费视频 | 国产免费成人在线视频 | 青青视频国产在线播放 |