検索
ホームページウェブフロントエンドCSSチュートリアル3階層カスケードメニューのiframe作成の詳細説明

原点
そのタスクは元々新しい同僚に割り当てられていましたが、新しい同僚は始めるのが遅く、機能をオンラインにしたいと考えていたため、自分たちでやるしかありませんでした。

タスク: 第 1 レベルの列のみを含む元のメニューを、3 レベルのカスケードをサポートするメニューに調整します。

実装: マウスを第 1 レベルのメニューの上に置くと、第 2 レベルのメニューがマウスがホバーしているときに、特定の セカンダリ メニュー、第 3 レベルの ドロップダウン メニュー がポップアップするとき、従来のコードは次のとおりです:

<p id="main">
    <iframe src=&#39;navbar.do&#39; width=800 height=40></iframe>
    <iframe src=&#39;main_content.do&#39;></iframe>
</p>

発生した問題:

iframe を使用してページの navigation バーとコンテンツ領域をそれぞれ読み込み、上記のことを実現します。これには何も問題はありません (iframe を頻繁に使用することは実際にはベストプラクティスではありません)。しかし、新しく追加された 2 番目と 3 番目の -レベル列は元のページ構造を破壊します。ナビゲーション バーの高さは固定されているため、ドロップダウン メニューを追加して高さを固定すると、ドロップダウン メニューのコンテンツがそれを含む iframe によって隠れてしまいます。

3階層カスケードメニューのiframe作成の詳細説明

レンダリング: 赤い線は、上部と下部の iframe の間の境界線です

最初に思い浮かぶ直感的な解決策は、iframe からナビゲーション バーのコンテンツを削除して、メイン ページに配置することです。

<p id="main">
    <p id="nav-bar"></p>
    <iframe src=&#39;main_content.do&#39;></iframe>
</p>

問題は解決しました。感情もあります。それは、次のとおりです。

コーダーが不足しているわけではありませんが、デザイナーが不足しています。何も考えずにデザインするのは詐欺です

もう一度考えてください
この質問に戻ります。 、最初のデザインについて考えてください、著者 2 つのリクエストは、ページのナビゲーション バーとメイン コンテンツ領域をそれぞれロードするために使用されます。一般的に、ホームページのコンテンツ領域のビジネス ロジックは決定されるため、コンテンツ領域は決まりません。 iframe を使用して実装する必要があります。合理的な ページ レイアウト は次のようになります

<p id="main">
    <p id="nav-bar"></p>
    <p id="content"></p>
</p>

追加
テスターが急いでやって来て、また問題が見つかったと心配そうに言いました。見られますが、コンテンツに表示されるビデオは、ドロップダウン メニューの一部をブロックします。その効果は次のとおりです:

3階層カスケードメニューのiframe作成の詳細説明

レンダリング

ビデオがロードされると、ドロップダウン メニューの緑色の部分が表示されます。ビデオでカバーされ、表示は不完全になります。
実際のビジネス シナリオを説明します。ビデオは、ページの最初のページを動的にロードすることによって、埋め込みタグを動的に生成します。ビデオを再生します

なぜ
z-index 属性 を動的に生成された埋め込み要素に設定できるのでしょうか?うまくいかなかったのが非常に残念でした。
その理由は何ですか?
後で、Flash のレンダリング モードの wmode パラメータを発見しました。デフォルトでは、wmode=window は主に効率性を考慮して設定されており、wmode=Opaque を設定すると、Flash は常にそれと重なる HTML をカバーします。このような問題がある場合、Flash はブラウザの HTML レンダリング面の上に表示されず、他の要素と同じページ上に表示されます。具体的な情報はここにあります。

次のステップは、スクリプトによって動的に生成された埋め込み要素を見つけて、wmode パラメーターを Opaque に設定することです。コードは次のとおりです。

var timer = setInterval(function(){
    var elem = document.getElementsByTagName("embed")[0];
    if( elem ){
        elem.setAttribute("wmode","opaque");
        clearInterval(timer);
    }
}, 100 );

Is it OK!
問題はまだ同じであることがわかりました。何が起こっているのでしょうか。なぜ機能しないのでしょうか?
wmode は Flash のレンダリング モードを設定するために使用されます。コード内の embed 要素は動的に生成されるため、embed 要素を見つけてレンダリング モードを設定すると、その wmode を再度設定すると Flash がレンダリングされます。はい、どうすればいいですか?

  • 問題を解決するにはメーカーに連絡し、埋め込み要素を生成するときにレンダリング モードをデフォルトで不透明に指定するようにスクリプトに依頼してください。適時性は比較的遅いはずですが、メーカーが私たちの提案を採用するかどうかは不明です。

  • embed 要素は動的に生成されるため、自分でも同じことを行うことができますか? embed 要素を見つけたら、embed 要素を変更し、フラッシュ メーカーによって生成された embed 要素を削除し、変更した embed 要素を挿入します。

【関連おすすめ】

1. 無料のCSSオンラインビデオチュートリアル

3. php.cn Dugu Jiijian (2) - CSSビデオチュートリアル

以上が3階層カスケードメニューのiframe作成の詳細説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

この投稿では、Blackle Moriは、CohostのHTMLサポートの限界を押し広げようとしている間に見つかったハックのいくつかを示します。あえてこれらを使用してください、あなたもCSS犯罪者とラベル付けされないようにしてください。

カーソルの次のレベルCSSスタイリングカーソルの次のレベルCSSスタイリングApr 23, 2025 am 11:04 AM

CSSを備えたカスタムカーソルは素晴らしいですが、JavaScriptを使用して次のレベルに物事を引き出すことができます。 JavaScriptを使用して、カーソル状態間で移行し、カーソル内に動的テキストを配置し、複雑なアニメーションを適用し、フィルターを適用できます。

Worlds Collide:スタイルクエリを使用したキーフレーム衝突検出Worlds Collide:スタイルクエリを使用したキーフレーム衝突検出Apr 23, 2025 am 10:42 AM

2025年には、互いに互いに跳ね返る要素を伴うインタラクティブなCSSアニメーションは、CSSにPongを実装する必要はありませんが、CSSの柔軟性とパワーの増加はLee&#039;の疑いを補強します。

UI効果にCSSバックドロップフィルターを使用しますUI効果にCSSバックドロップフィルターを使用しますApr 23, 2025 am 10:20 AM

CSSバックドロップフィルタープロパティを使用してユーザーインターフェイスをスタイルするためのヒントとコツ。バックドロップフィルターを複数の要素間でレイヤー化する方法を学び、それらを他のCSSグラフィカル効果と統合して、精巧なデザインを作成します。

微笑んでいますか?微笑んでいますか?Apr 23, 2025 am 09:57 AM

まあ、SVG&#039;の組み込みのアニメーション機能は、計画どおりに非推奨されることはありませんでした。確かに、CSSとJavaScriptは負荷を運ぶことができる以上のものですが、以前のようにSmilが水中で死んでいないことを知っておくのは良いことです

「かわいい」は見る人の目にあります「かわいい」は見る人の目にありますApr 23, 2025 am 09:40 AM

イェーイ、テキストワラップのジャンプを見てみましょう:サファリテクノロジーのプレビューにかなり着陸してください!しかし、それがChromiumブラウザーでの仕組みとは異なることに注意してください。

CSS-Tricks XLIIIを記録しますCSS-Tricks XLIIIを記録しますApr 23, 2025 am 09:35 AM

このCSS-Tricksアップデートは、アルマナック、最近のポッドキャスト出演、新しいCSSカウンターガイド、および貴重なコンテンツを提供するいくつかの新しい著者の追加の大幅な進歩を強調しています。

Tailwind&#039;の@Apply機能は、響きよりも優れていますTailwind&#039;の@Apply機能は、響きよりも優れていますApr 23, 2025 am 09:23 AM

ほとんどの場合、人々はTailwind&#039;の@Apply機能を紹介します。このように展示されたとき、@Applyはまったく有望な音をしません。だからobvio

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール