zoukankan      html  css  js  c++  java
  • iframe 里的高度适应的问题

    iframe 这个东西功能是很强大,但是有一个巨大的问题就是高度自适应的问题;

    不过这个问题,百度或者谷歌上有很多解决办法,但是,很多时候都有兼容性问题; 所有我就每个方法都试了一遍,终于找到了一个

    感觉很牛的样子,不需要用到js 就可以让iframe 里的内容覆盖整个页面,感觉很舒服。哈哈哈

    <html>
    
        <head>
            <meta charset="UTF-8">
            <title></title>
        </head>
    <style type="text/css">
        body {margin-left: 0px;margin-top: 0px;margin-right: 0px;margin-bottom: 0px;overflow: hidden;}
    </style>
        <body>
            
            <div>
                <iframe id="external-frame" src="https://cdn-huoshu.fire2333.com/landpages/rxgl/template/4039/index.php?pt=7590&footer_id=1" width="100%" height="100%" scrolling=" no"></iframe>
            </div>
        </body>
    
    </html>

    这样,就可以完美的解决这个问题啦;

    有三点要注意哦:

    第一:一定要已html开头,而不是用<!DOCTYPE html>开头

    第二:body的overflow:hidden ; 一定不要忘记加;

    第三:iframe 的高度100%一定要记得加上。这样就解决了我的问题了;

    虽然不知道这种实现的原理是什么,希望有知道的朋友可以告诉我下。

    这在跨域的时候,是真的好用,尤其是不能修改iframe 里的页面的时候;

    同域的话:

    有一段js代码就可以解决这个问题啦;

    function setIframeHeight(iframe) {
    if (iframe) {
    var iframeWin = iframe.contentWindow || iframe.contentDocument.parentWindow;
    if (iframeWin.document.body) {
    iframe.height = iframeWin.document.documentElement.scrollHeight || iframeWin.document.body.scrollHeight;
    }
    }
    };
    
    window.onload = function () {
    setIframeHeight(document.getElementById('external-frame'));
    };

    在页面里插入这个就好啦;

    我觉得这两个方法完美的解决了我公司一些php们的问题。

    天天都在用iframe结果用的还那么不清楚,实在搞不懂。

    尤其是某个php,什么css js html都不会,真心不知道他是怎么成为php的。连获取元素都不会。很气

    瞎抱怨下,反正没人看。哈哈哈哈,总之这两种方法我觉得很好。赞;

  • 相关阅读:
    Chapter 7 Integrity(完整性), Views(视图), Security(安全性), and Catalogs(目录)
    Qt计时器
    linux命令:linux文件处理命令
    JSON.stringify()的不常见用法
    flex知识点归纳
    css伪类
    开发资源汇总
    Math.cbrt() Math.sqrt() Math.pow()
    代码开发注意事项和规范
    关于数组数据容易忽略的点
  • 原文地址:https://www.cnblogs.com/AiMuzi/p/8867107.html
Copyright © 2011-2022 走看看