簡単な説明<br />IE6および7では、一般的なaタグ(HTMLで記述され、DOM操作によってページに挿入されるaタグ)において、hrefの値が相対パスである場合、元のhrefの値はa.getAttribute("href")を介して直接取得されず、a.getAttribute("href",2)を介して取得されます。ただし、このaタグがinnerHTMLを介して挿入されている場合、a.getAttribute("href",2)を介しても元のhrefの値を取得できません。 innerHTML='<a href="/haha">test</a>' とすると、IE6,7 ではそれに対する互換処理が行われ、何らかの追加が行われると予測されます。このとき、outerHTML を通して見ると、a の href がすでに完全なアドレスになっています -_-! img の src でも同様の状況が発生すると言われています。 コードをコピー コードは次のとおりです。<!doctypehtml> <html lang="ja"> <ヘッド> <メタ文字セット="UTF-8"> <title>テスト</title> </head> <本文> <a id="a" href="" onclick=".getAttribute(\"href\",2)">テスト</a> </本文> </html> IE6 または 7 でクリックすると、大きな「/haha」がポップアップ表示されます。 ! !何か他のことが起こっているのではないかと疑い始めました。このとき、a タグがどのようにして (文字列ベースの js テンプレート、innerHTML) 取得されるのかを考えました...そこで、次のコードでシミュレートしました。 コードをコピー コードは次のとおりです。<!doctypehtml> <html lang="ja"> <ヘッド> <メタ文字セット="UTF-8"> <title>テスト</title> </head> <本文> <div id="test"></div> <スクリプト> document.getElementById("test").innerHTML = '<a id="a" href="/haha" onclick="alert(this.getAttribute(\'href\',2));return false;">テスト</a>'; </スクリプト> </本文> </html> 再度テストしました...妹の...問題が再発しました!実際のテストでは、を生成した後、再度 a に対して setAttribute("href","/haha",2) を実行し、次に getAttribute("href",2) を実行すると、"/haha" が返されます。でも、こういうことをテンプレートでやるのは、あまりにも気持ち悪いので、きっぱり諦めましょう!フランクのアドバイスに耳を傾けた方が良いでしょう... 2 つのリンク要素を識別する属性を追加するだけで、行き詰まらないようにしましょう。 もう一度ドリル-_-!: コードをコピー コードは次のとおりです。<!doctypehtml> <html lang="ja"> <ヘッド> <メタ文字セット="UTF-8"> <title>テスト</title> </head> <本文> <div id="test"></div> <スクリプト> var テスト = document.getElementById("テスト"); var a = document.createElement("a"); var txt = document.createTextNode("テスト"); a.href="/はは"; a.onclick=関数() { alert(this.getAttribute('href',2));//"/はは" false を返します。 }; txt を追加します。 テストします。 </スクリプト> </本文> </html> 最後に、innerHTML を通じてノードを挿入する場合、IE6 と 7 は正しいと判断する「エラー許容」処理を実行するのではないかと思います...そして、私は間違っていました... |
<<: IDEA が Docker を統合してリモート展開を実現するための手順
>>: MySQL の undo、redo、binlog の違いを簡単に分析します
Discuz! フォーラムにはバックグラウンドで多くの設定オプションがあり、これらの設定オプションを...
目次1. 観察可能2. 高階関数3. エクスプレスボックスモデル3.1. エクスプレスボックスモデル...
データ内に次のような特徴を持つ「 ' 」などの文字が含まれることがあります。 &# ...
目次最初のステップ: 2 番目のステップは、request.js で関連する構成を行うことです。re...
1. 前提条件インポートには require.context メソッドを使用します。vite で作成...
目次1. ノードをインストールする2. Commander.jsをインストールする3. JavaSc...
⑴ 内容によって形式が決まります。まず内容を充実させ、次にブロックに分割し、トーンを決め、最後に細部...
この記事では、MySQL 5.7のインストールと設定のチュートリアルを参考までに紹介します。具体的な...
1. ファイアウォールルールを設定する例1: ポート8080を外部に公開する ファイアウォールコマン...
--データベースに接続するとき、ホストとユーザーのマッチングルール公式ドキュメント: https:/...
目次序文-リンクカスタムネットワーク質問する序文前回は、 -Linkパラメータを使用してコンテナ間の...
クロージャは、純粋関数型プログラミング言語の伝統的な機能の 1 つです。クロージャをコア言語構造の不...
質問: 360ブラウザの互換モードなど、一部のブラウザでは、 <td style="...
1. システム環境[root@localhost ホーム]# cat /etc/redhat-re...
目次序文1. 背景2. シミュレーションテスト3. 結論要約する序文もし私が罠に陥っていなかったら、...