今日、ふとリッチテキストエディタの制作原理を見直してみようと思いました。それで、彼は何も言わずにそれをやり始めました。 1 年前にシンプルなリッチ テキスト エディターを作成したので、その印象がまだ残っています。しかし、書いたコードを実行すると、問題が見つかりました。 コードをコピー コードは次のとおりです。var ifr = document.createElement('iframe'); 幅 = 300; ifr.高さ = 300; var idoc = ifr.contentDocument || ifr.contentWindow.document; idoc.designMode = 'オン'; コンテンツ編集可能 = true; idoc.write('<html><head><style>body{ margin:0px; }</style></head><body></body></html>'); ドキュメント本体に子要素を追加します(ifr); 上記のコードを見て、何か抜けているところを見つけましたか? 私と同じような経験をした友人がいなかったら、おそらくこのコードの何が間違っているのか分からないと思います。それなら、走りに行ってみたらいいでしょう。すぐに問題が見つかるかもしれません。 以下に答えを明らかにします: オブジェクトが見つからない場合、このコードは例外をスローします。見つからないオブジェクトはどれですか?ドキュメント オブジェクトが見つかりません。どうしたらいいですか?ドキュメント オブジェクトが見つからないのはなぜでしょうか?もちろん、このドキュメント オブジェクトは iframe のドキュメント オブジェクトです。リッチ テキストを扱ったことがある人なら誰でも、iframe を編集可能に設定する前に、まず iframe のドキュメント オブジェクトを取得する必要があることを知っています。しかし、なぜドキュメント オブジェクトを取得できないのでしょうか?ここであなたを不安にさせるつもりはありません。私の解決プロセスについてお話ししましょう。 まず Google にアクセスして、文書の入手方法が正しいことを確認しました。それで、それは Chrome のせいなのかなと思いました。 Chrome がこれら 2 つのオブジェクトをサポートしていない可能性はありますか?そこでFirefoxに切り替えました。結果は同じです。そうすると、問題はあなた自身のコードにあることは間違いありません。 その後、インターネット上のコードと比較したところ、appendChild の位置が少し間違っていることがわかったので、ドキュメント オブジェクトを取得する前にそれを前方に移動しました。 コードをコピー コードは次のとおりです。var ifr = document.createElement('iframe'); 幅 = 300; ifr.高さ = 300; ドキュメント本体に子要素を追加します(ifr); var idoc = ifr.contentDocument || ifr.contentWindow.document; idoc.designMode = 'オン'; コンテンツ編集可能 = true; idoc.write('<html><head><style>body{ margin:3px; word-wrap:break-word; word-break: break-all; }</style></head><body></body></html>'); その結果、すべてがスムーズに進みました。次にエラーを分析しました。実際、このエラーの背後にある原理は非常に単純です。 iframe には実際には別のドキュメントが含まれており、このドキュメントは初期化された後にのみドキュメント オブジェクトを持つことができることは誰もが知っています。 iframe 要素が DOM ツリーに追加されない場合、iframe 内のドキュメントは初期化されません。したがって、コードの先頭では、ifr 変数で取得した contentDocument 値は null であり、これは iframe 内のドキュメントがこの時点では初期化されていないことを意味します。 この行に従って、他のノードの初期化をチェックしたところ、他の要素ノードが作成されると、DOM ツリーに追加されるかどうかに関係なく、独自のプロパティとメソッドを持つことがわかりました。つまり、iframe は多くの要素ノードの中で外れ値です。 |
<<: CSS3 カスタムスクロールバースタイル::webkit-scrollbar サンプルコード詳細説明
>>: MySQLフィールド定義でnullを使用しない理由の分析
目次プロトタイプチェーンプロトタイプチェーンに基づいてシンプルなJQueryライブラリを実装すること...
公式ドキュメント: https://dev.mysql.com/doc/refman/5.7/en/...
1: 速度と読み込み方法の違いdivとtableの違いは速度ではなく、読み込み方法です。速度はネット...
最近、「フロントエンドキャッシュ」という新しい要件が作成されました要件背景: フォームへの高頻度の繰...
フローティング要素は、親要素の高さを縮小します。要素を float float:left/right...
目次ネイティブJS GETリクエストの送信方法投稿リクエストの送信方法パラメータ付きのGETリクエス...
この記事では、JavaScript Canvasの動的なワイヤーフレーム効果を描画する具体的なコード...
エクスポートデフォルト({ URL、 メソッド = 'GET'、 データ = nu...
目次1. すべて選択2. 商品の数量を増やすか減らす3. 商品の小計を変更する4. 合計と合計額を計...
1. 解凍版のインストール(1)圧縮パッケージをダウンロードし、ディスクの場所に解凍します。圧縮パッ...
目次1. はじめに2. 本文2.1 フィールドの連結2.2 フィールドでの算術計算の実行1. はじめ...
目次1. コマンド2. docker-compose.yml 3. Dockerファイル4. 直接変...
大画面のデジタル スクロール効果は、最近の作業における大画面 UI ダイアグラムから生まれました。U...
この記事では、ネイティブ JS で実装されたブラインドの特殊効果を紹介します。効果は次のとおりです。...
最近、H1 については多くの議論が行われていますが (記事のコンテンツ ページ内)、おおよそ 2 つ...