• 获取子iframe框架的元素


    我们常常遇到使用iframe框的时候,该iframe框不能根据自己内部的内容撑起来的这种问题
    必要条件:不能在跨域的情况下。。。本地可以放到localhost下进行测试

    //父页面index.html页面
    <iframe id="ifr" src="iframe1.html" frameborder="0" width="100%" name="iframe1"></iframe>
    
    //框架iframe.html
    <body>
        <div id="btn1">
            我是iframe1的内容<br/>我是iframe1的内容<br/>我是iframe1的内容<br/>我是iframe1的内容<br/>我是iframe1的内容<br/>我是iframe1的内容<br/>我是iframe1的内容<br/>我是iframe1的内容<br/>我是iframe1的内容<br/>我是iframe1的内容<br/>我        是iframe1的内容<br/>我是iframe1的内容<br/>我是iframe1的内容<br/>我是iframe1的内容<br/>
        </div>
    </body>
    

    如何 获取子iframe框 的元素呢??

    window.frames['iframe1'].document.getElementById('btn1');//获取name为iframe1的btn1
    
    //比如你可以给它添加事件: 
    window.frames['iframe1'].document.getElementById('btn1').onclick = function(){
        alert(1)
    }
    

    注意 要将代码放到window.onload = function(){...}里,否则因为没有加载完全dom节点会报错

    如何 获取父iframe框 的元素呢??

    parent.document.getElementById('click-btn').onclick = function() {
    		console.log('打印父元素中点击的节点内容:'+ this.innerHTML);
    	}//在iframe框中获取父页面的节点
    

    最后,让子iframe框架高度自适应代码:

     // 计算页面的实际高度,iframe高度自适应
      function calcPageHeight(doc) {
          var cHeight = Math.max(doc.body.clientHeight, doc.documentElement.clientHeight)
          var sHeight = Math.max(doc.body.scrollHeight, doc.documentElement.scrollHeight)
          var height  = Math.max(cHeight, sHeight)
          return height
      }
      var ifr = document.getElementById('ifr')
      ifr.onload = function() {
          var iDoc = ifr.contentDocument || ifr.document
          var height = calcPageHeight(iDoc)
          ifr.style.height = height + 'px'
      }
  • 相关阅读:
    Spring Boot初学
    Spring MVC必须知道的执行流程
    日志Log4j使用
    SpringMVC处理中文乱码
    Maven设置阿里云镜像
    Maven项目中配置文件导出问题
    使用Limit实现分页
    web项目中设置首页
    JVM 学习笔记记录
    Python内存管理&垃圾回收机制
  • 原文地址:https://www.cnblogs.com/geekfeier/p/6928034.html
Copyright © 2020-2023  润新知