ホームページ  >  記事  >  ウェブフロントエンド  >  Cross-domain_html/css_WEB-ITnose での iframe 適応高さ

Cross-domain_html/css_WEB-ITnose での iframe 適応高さ

WBOY
WBOYオリジナル
2016-06-24 11:28:501330ブラウズ

最近私はある要件に取り組んでいます。その要件の一般的な背景は次のとおりです: ページ内の 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 同一オリジン制限はありません)

記事参照: フロントエンド開発ブログ

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。