设置动态高度 -
- 我们需要与跨域 iFrame 和父级通信
- 然后我们可以将 iframe 的滚动高度/内容高度发送到父窗口
1 用于交流
我更喜欢 - https://ternarylabs.github.io/porthole/
2 实施
检测 iframe 高度变化 - 使用https://marcj.github.io/css-element-queries/
<script src="https://raw.githubusercontent.com/marcj/css-element-queries/master/src/ResizeSensor.js"></script>
<script src="https://raw.githubusercontent.com/ternarylabs/porthole/master/src/porthole.min.js"></script>
对于其余的实施,请参阅要点 -
https://gist.github.com/mohandere/a2e67971858ee2c3999d62e3843889a8   
父窗口:
(function(){
'use-strict';
//This soultion we have used  - https://ternarylabs.github.io/porthole/
// example - 
var iFrameId: 'guestFrame',
window.onload = function(){
    // Create a proxy window to send to and receive
    // messages from the iFrame
    var windowProxy = new Porthole.WindowProxy(
        'http://other-domain.com/', iFrameId);
    var $viewPort = $('#'+iFrameId);
    // Register an event handler to receive messages;
    windowProxy.addEventListener(function(messageEvent) {
      
      if( messageEvent.data.height == $viewPort.height() ){
        return;
      }
        $viewPort.height(messageEvent.data.height);
    });
    Porthole.WindowProxyDispatcher.start();
};
})();
iframe 窗口:
(function(){
'use-strict';
/**
 * Iframe to Parent window communication
 * sample iframe- <iframe id="guestFrame" name="guestFrame" src="http://other-domain.com/">
 * </iframe>
 * Uses https://ternarylabs.github.io/porthole/
 * Uses https://marcj.github.io/css-element-queries/  
 */
window.onload = function(){
  var proxy = window.proxy  = new Porthole.WindowProxy('http://parent-domain.com/');
  proxy.addEventListener(function(messageEvent) {
      // handle event
  });
  //Height setup
  var iframeHeight = 0;
  
  var element = document.getElementsByTagName("BODY")[0];
  new ResizeSensor(element, function() {
    
    var scrollHeight = $('body').outerHeight();
    if (iframeHeight === scrollHeight) return false;
    
    iframeHeight = scrollHeight;
    proxy.post({
      height: scrollHeight,
    });
    
  });
  Porthole.WindowProxyDispatcher.start();
};
})();