<script>
//ifram自适应高度
var browserVersion = window.navigator.userAgent.toUpperCase();
var isOpera = false;
var isFireFox = false;
var isChrome = false;
var isSafari = false;
var isIE = false;
var iframeTime;
function reinitIframe(iframeId, minHeight) {
try {
var iframe = document.getElementById(iframeId);
var bHeight = 0;
if (isChrome == false && isSafari == false)
bHeight = iframe.contentWindow.document.body.scrollHeight;
var dHeight = 0;
if (isFireFox == true)
dHeight = iframe.contentWindow.document.documentElement.offsetHeight + 2;
else if (isIE == false && isOpera == false)
dHeight = iframe.contentWindow.document.documentElement.scrollHeight;
else
bHeight += 23;
var height = Math.max(bHeight, dHeight);
if (height < minHeight) height = minHeight;
iframe.style.height = height + "px";
} catch (ex) { }
}
function startInit(iframeId, minHeight) {
isOpera = browserVersion.indexOf("OPERA") > -1 ? true : false;
isFireFox = browserVersion.indexOf("FIREFOX") > -1 ? true : false;
isChrome = browserVersion.indexOf("CHROME") > -1 ? true : false;
isSafari = browserVersion.indexOf("SAFARI") > -1 ? true : false;
if (!!window.ActiveXObject || "ActiveXObject" in window)
isIE = true;
reinitIframe(iframeId, minHeight);
if (iframeTime != null)
clearInterval(iframeTime)
iframeTime = window.setInterval("reinitIframe('" + iframeId + "'," + minHeight + ")", 100);
}
</script>
网上其它都没啥用,关键还是看最后那个定时查找的iframeTime = window.setInterval("reinitIframe('" + iframeId + "'," + minHeight + ")", 100);
调用方法:
<iframe id="main" name="main" src="" style="padding: 0px;width: 100%;" frameborder=0 scrolling="no"></iframe>
<script type="text/javascript">
//startInit('main', 0);
</script>
这个调用方法可以按自己 需要放在想放的地方,比如,下拉框选择事件中,只有在选择时才触发此事件