天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

Iframe 自適應高度并實時監控高度變化的js代碼

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

2、然后看看怎么獲取Iframe中的頁面的高度。
其實最麻煩的就是怎么讓獲取的高度準確,不同的方式不同的瀏覽器中獲取到的值都會不一樣!暈啊~~。參考了多方意見得出以下Javascript函數(doc參數為window.document對象):
復制代碼 代碼如下:
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是與當前頁面的高度一致的,
//其他的跳轉幾次后就會變的混亂,不知道是依照什么取的值!
//似乎跟包含它的窗口的大小變化有關
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);//取最大的值,某些情況下可能與實際頁面高度不符!
*/
return docHei;
}

3、最后修改Iframe的高度,并用一個定時器來不間斷檢查它包含的頁面的高度變化。
復制代碼 代碼如下:
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);//每隔半秒執行一次
}
runResizeTask();

在這里就沒有去考慮被包含的頁面中是否有折疊、隱藏/展現的情況了!
完整js代碼
復制代碼 代碼如下:
<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是與當前頁面的高度一致的,
//其他的跳轉幾次后就會變的混亂,不知道是依照什么取的值!
//似乎跟包含它的窗口的大小變化有關
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);//取最大的值,某些情況下可能與實際頁面高度不符!
*/
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秒執行一次
}
runResizeTask();
</script>

JavaScript技術Iframe 自適應高度并實時監控高度變化的js代碼,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲精品无码国产爽快A片百度 | 亚洲色图p| 免费三级黄色 | 中文字幕无线观看不卡网站 | 男男肉肉互插腐文 | 久久是热这里只有精品 | 日韩欧美视频一区二区在线观看 | 成人永久免费视频 | 亚洲免费三区 | 爱做久久久久久 | 肉动漫无修在线播放 | 98色精品视频在线 | 国产亚洲精品久久久久久国模美 | 贤妻良母电影日本 | XXXchinese国产HD| 亚洲视频精选 | 日本午夜福利无码高清 | 精品国产品国语在线不卡丶 | 影音先锋影院中文无码 | 午夜性爽视频男人的天堂在线 | 色偷偷91综合久久噜噜 | 特级做A爰片毛片免费69 | 色橹橹欧美在线观看视频高 | 2019中文字幕乱码免费 | 美女张开腿露出尿口扒开来摸动漫 | 97视频免费在线 | 草久热的视频在线观看 | 挠黑色超薄丝袜脚心vk40分钟 | 国产欧美无码亚洲 | 亚洲综合国产在不卡在线 | 久久综合网久久综合 | 一级片mp4| 高清mv视频免费观看 | 亚洲精品国产乱码AV在线观看 | 范冰冰hdxxxx| 精品九九视频 | 亚洲 欧美 国产 综合久久 | 黑色丝袜美女被网站 | 国内精品蜜汁乔依琳视频 | 亚洲精品免费在线视频 | 色丁香婷婷综合缴情综 |