ホームページ ウェブフロントエンド htmlチュートリアル iframeノードの初期化に関する議論_HTML/Xhtml_Webページ制作

iframeノードの初期化に関する議論_HTML/Xhtml_Webページ制作

May 16, 2016 pm 04:38 PM
iframe 初期化 ノード

今日は突然、リッチ テキスト エディターの作成原理を復習したいと思いました。それで私は何も言わずに少しずつそれを始めました。 1 年前にシンプルなリッチ テキスト エディターを作成したので、おそらく今でも印象に残っていることがあります。しかし、私が書いたコードを実行すると、問題が見つかりました。

コードをコピーします
コードは次のとおりです。

var ifr = document.createElement('iframe');
ifr.width = 300;
var idoc = ifr.contentDocument || ifr .contentWindow.document;
idoc.designMode = 'on';
idoc.contentEditable = true; ');
document.body.appendChild(ifr); > 上記のコードを見てください。エラーは見つかりましたか?

私と同じような経験をした子供たちがいなかったら、おそらくこのコードの何が問題なのか理解できないと思います。だから、走ってみるのもいいかもしれません。問題はすぐに見つかるかもしれません。
以下に答えを明らかにしましょう:

このコードはオブジェクトが見つからない例外をスローします。見つからないオブジェクトはどれですか?ドキュメント オブジェクトが見つかりません。何ですか?ドキュメント オブジェクトが見つからないということはどのようにして起こり得るのでしょうか?もちろん、このドキュメント オブジェクトは iframe のドキュメント オブジェクトです。リッチ テキストを作成したことがある人なら、編集可能にする前に、まず iframe のドキュメント オブジェクトを取得する必要があることを知っています。しかし、なぜドキュメントオブジェクトを取得できないのでしょうか?ここではあまり大げさなことはしません。私の解決プロセスについて話しましょう。

まず、Google で調べたところ、書類の入手方法は正しかったことがわかりました。じゃあChromeだったのかな? Chrome はこれら 2 つのオブジェクトをサポートしていませんか?そこでFirefoxに切り替えました。結果は依然として同じです。その場合、確かなことは、それはあなた自身のコードに問題があるに違いないということです。

その後、インターネット上のコードを比較すると、appendChild の位置が少し間違っていることがわかったので、事前に移動してドキュメント オブジェクトを取得しました。





コードをコピー
コードは次のとおりです。 var ifr = document.createElement('iframe'); >ifr.width = 300; ifr.body.appendChild(ifr);
var idoc = ifr.contentWindow.document; designMode = 'on';
idoc.contentEditable = true;
idoc.write('');


結果はスムーズに実行されました。そこで今回のエラーを分析してみました。実際、このエラーの理由は非常に単純です。 iframe には実際には別のドキュメントが含まれており、このドキュメントは初期化された後にのみドキュメント オブジェクトを持つことができることは誰もが知っています。また、iframe 要素が DOM ツリーに追加されない場合、iframe 内のドキュメントは初期化されません。したがって、最初のコードでは、取得した ifr 変数の contentDocument 値は null です。これは、iframe 内のドキュメントが現時点では初期化されていないことを意味します。

この行に続いて、他のノードの初期化ステータスを確認したところ、実際、他の要素ノードが作成されると、それらが DOM ツリーに追加されるかどうかに関係なく、独自の属性とメソッドを持つことがわかりました。ない。言い換えれば、iframe は多くの要素ノードの中で外れ値です。
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホット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 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

HTML で IFrame をトリミングするにはどうすればよいですか? HTML で IFrame をトリミングするにはどうすればよいですか? Aug 29, 2023 pm 04:33 PM

インラインフレームはHTMLではiframeと呼ばれます。ラベルは、ブラウザがスクロール バーや枠線を使用してさまざまなドキュメントを表示できる、コンテンツ内の長方形の領域を指定します。現在の HTML ドキュメント内に別のドキュメントを埋め込むには、インライン フレームを使用します。要素への参照は、HTMLiframe name 属性を使用して指定できます。 JavaScript では、要素への参照も name 属性を使用して行われます。 iframe は基本的に、現在表示されている Web ページ内に Web ページを表示するために使用されます。 iframe を含むドキュメントの URL は、「src」属性を使用して指定されます。構文 以下は HTML <iframesrc="URL"title="d の構文です。

iframe の読み込みが遅いのはなぜですか? iframe の読み込みが遅いのはなぜですか? Aug 24, 2023 pm 05:51 PM

iframe の読み込みが遅い原因には、主にネットワーク遅延、リソース読み込み時間の長さ、読み込み順序、キャッシュ メカニズム、セキュリティ ポリシーが含まれます。詳細な紹介: 1. ネットワーク遅延: ブラウザーが iframe を含む Web ページを読み込むとき、iframe 内のコンテンツを取得するためにサーバーにリクエストを送信する必要があります。ネットワーク遅延が大きい場合、コンテンツの取得に時間がかかります。 ; 2. リソースの読み込み時間が長い場合、リソースのサイズが大きい場合、またはサーバーの応答時間が長い場合、読み込み速度はより明らかに遅くなります; 3. 読み込みシーケンス、等

ダイナミック リンク ライブラリの初期化ルーチンが失敗した場合の対処方法 ダイナミック リンク ライブラリの初期化ルーチンが失敗した場合の対処方法 Dec 29, 2023 am 10:30 AM

解決策: 1. アプリケーションを再インストールします; 2. DLL を修復または再インストールします; 3. システムの復元またはチェックポイントの回復; 4. システム ファイル チェッカー (SFC) を使用してスキャンします; 5. スタートアップ項目とサービスを確認します; 6. ツールを使用します; 7.公式ドキュメントやフォーラムを確認する; 8. セキュリティ ソフトウェアを検討する; 9. イベント ビューアを確認する; 10. 専門家の助けを求めるなど。

iframe の data-id は何を意味しますか? iframe の data-id は何を意味しますか? Aug 28, 2023 pm 02:25 PM

iframe の data-id は、特定の要素の識別子を格納するために HTML タグで使用されるカスタム属性を指します。 data-id 属性を使用すると、iframe 要素に一意の識別子を追加して、JavaScript で操作およびアクセスできるようにすることができます。 data-id 属性の命名は、特定のニーズに応じてカスタマイズできますが、一意性と読みやすさを確保するために、通常はいくつかの命名規則に従います。 data-id 属性を使用して、特定の iframe を識別および操作することもできます。

win7でパソコンを初期化する方法 win7でパソコンを初期化する方法 Jan 07, 2024 am 11:53 AM

win7 システムは非常に優れた高性能システムであり、win7 を継続的に使用していると、多くの友人が win7 でコンピュータを初期化する方法を尋ねてきます。今日は、エディターが win7 コンピューターの工場出荷時の設定を復元する方法を紹介します。 win7 でコンピュータを初期化する方法に関する関連情報: 画像とテキストによる詳細な手順 手順: 1. 「スタート メニュー」を開いて入ります。 2. 左側の下部をクリックして設定を入力します。 3. Win10 の更新と回復の設定インターフェイスで、選択します。 4. 以下の「すべてのコンテンツを削除して Windows を再インストールする」をクリックします。 5. 以下の「初期化」設定が表示されるので、クリックします。 6. 「コンピュータには複数のドライブがあります」設定オプションを入力します ここには 2 つのオプションがあり、状況に応じて選択できます。

iframeの読み込みイベントとは何ですか? iframeの読み込みイベントとは何ですか? Aug 28, 2023 pm 01:55 PM

iframe の読み込みイベントには、onload イベント、onreadystatechange イベント、onbeforeunload イベント、onerror イベント、onabort イベントなどが含まれます。詳細説明: 1. onload イベント、iframe のロード後に実行される JavaScript コードを指定、2. onreadystatechange イベント、iframe の状態が変化したときに実行される JavaScript コードを指定、など。

PCでグラフィックスシステムを初期化できないエラーを修正 PCでグラフィックスシステムを初期化できないエラーを修正 Mar 08, 2024 am 09:55 AM

多くのゲーマーは、ゲームがグラフィックス システムの初期化に失敗するというイライラする問題に遭遇したことがあります。この記事では、この問題の背後にある一般的な理由を詳しく掘り下げ、すぐにボードに戻ってレベルをクリアできるシンプルかつ効果的な解決策を見つけます。したがって、Rollercoaster Tycoon、Assassin’s Creed、Tony Hawk’s Pro Skater などで「グラフィック システムを初期化できません」というエラー メッセージが表示される場合は、この記事で説明されている解決策に従ってください。初期化エラー グラフィックス システムを初期化できません。グラフィックカードはサポートされていません。グラフィックス システムを初期化できないエラー メッセージを修正する Rollercoaster Tycoon、Assassin's Creed、Tony Hawk's Pro Skater などのゲームでのグラフィックス システムを初期化できないエラー メッセージを解決するには、次の回避策を試すことができます。互換モード

win7のネットワーク設定をリセットする方法 win7のネットワーク設定をリセットする方法 Dec 26, 2023 pm 06:51 PM

win7 システムは非常に優れた高性能システムです。最近、多くの win7 システムの友人が win7 のネットワーク設定を初期化する方法を探しています。今日は、エディターが win7 コンピュータのネットワーク初期化の詳細を紹介します。見てみましょう。チュートリアルを見てください。 win7 でネットワーク設定を初期化する方法に関する詳細なチュートリアル: グラフィカルな手順: 1. [スタート] メニューをクリックし、[コントロール パネル] を見つけて開き、[ネットワークと共有センター] をクリックします。 2. 次に、「アダプターデバイスの変更」を見つけてクリックします。 3. 次に、開いたウィンドウで「ローカル エリア接続」を右クリックし、「プロパティ」をクリックします。 4. 開いたら、「インターネット プロトコル バージョン (TCP/IPv4)」を見つけてダブルクリックします。

See all articles