最近私はある要件に取り組んでいます。その要件の一般的な背景は次のとおりです: ページ内の iframe が他社のリスト ページに埋め込まれています
ブロガーの最初の反応は「とても簡単です!」です。コードの入力を開始してください
その結果、iframe がクロスドメインであり、埋め込まれたページの高さを取得できませんでした。そのため、表示される上下のスクロール バーは非常に醜いものでした。
それで私は偉大なマスターを探しにネットに行きました。ついに見つけました。言葉では言い表せないほど興奮しています。
物語の背景が説明されました。 /*********************************ゴージャスな分割線、笑*************** *** ************/
巨匠の例は大まかに次のようなものです:
www.a.com の下のページ a.html に www.b.com の下のページ c.html が含まれているとします。
www.a.com の下にある別のページ Agent.html をプロキシとして使用し、これを通じて iframe ページの高さを取得し、iframe 要素の高さを設定します
a.html には iframe:
1 <iframe src="http://www.b.com/c.html" id="Iframe" frameborder="0" scrolling="no" style="border:0px;"></iframe>
が含まれています次のコードを c.html に追加します:
1 <iframe id="c_iframe" height="0" width="0" src="http://www.a.com/agent.html" style="display:none" ></iframe>2 <script type="text/javascript">3 (function autoHeight(){4 var b_width = Math.max(document.body.scrollWidth,document.body.clientWidth);5 var b_height = Math.max(document.body.scrollHeight,document.body.clientHeight);6 var c_iframe = document.getElementById("c_iframe");7 c_iframe.src = c_iframe.src + "#" + b_width + "|" + b_height; // 这里通过hash传递b.htm的宽高8 })();9 </script>
最後に、agent.html に js を追加します:
1 <script type="text/javascript"> 2 var b_iframe = window.parent.parent.document.getElementById("Iframe"); 3 var hash_url = window.location.hash; 4 if(hash_url.indexOf("#")>=0){ 5 var hash_width = hash_url.split("#")[1].split("|")[0]+"px"; 6 var hash_height = hash_url.split("#")[1].split("|")[1]+"px"; 7 b_iframe.style.width = hash_width; 8 b_iframe.style.height = hash_height; 9 }10 </script>
agent.html は URL から幅と高さの値を取得し、高さを設定します。 iframe の幅 (agent.html は www.a.com 配下にあるため、a.html を操作する際の JavaScript 同一オリジン制限はありません)
記事参照: フロントエンド開発ブログ