ホームページ ウェブフロントエンド jsチュートリアル JavaScript ドキュメントの場所の比較_JavaScript スキル

JavaScript ドキュメントの場所の比較_JavaScript スキル

May 16, 2016 pm 07:05 PM
javascript 比較する

1. DOMElement.contains(DOMNode)

このメソッドは、DOM ノードが別の DOM 要素に含まれているかどうかを判断するために IE で初めて使用されました。

このメソッドは、CSS セレクターのトラバーサル (「#id1 #id2」など) を最適化する場合に役立ちます。 getElementById を介して要素を取得し、.contains() を使用して #id1 に実際に #id2 が含まれているかどうかを判断できます。

注: DOM ノードと DOM 要素が一貫している場合、要素にそれ自体を含めることはできませんが、 .contains() は true を返します。

これは、Internet Explorer、Firefox、Opera、Safari で実行できる単純な実行ラッパーです。


function contains(a, b) {
return a.contains ? a != b && a.contains(b) : !!(a.compareDocumentPosition(arg) & 16);
}
2. NodeA.compareDocumentPosition(NodeB)

このメソッドは DOM レベル 3 仕様の一部であり、2 つの DOM ノード間の相互の位置を決定できます。このメソッドは .contains() よりも強力です。このメソッドの応用例の 1 つは、DOM ノードを特定の正確な順序に並べ替えることです。

このメソッドを使用すると、要素の位置に関する一連の情報を決定できます。これらすべての情報はビット コード (ビット、バイナリ ビットとも呼ばれます) を返します。

それらについてはほとんど知られていません。ビットコードは複数のデータを単純な数値 (訳者注: 0 または 1) として格納します。最終的には個々の数値を開閉することになり (翻訳者注: 開閉は 0/1 に対応します)、それによって最終結果が得られます。

これは、NodeA.compareDocumentPosition(NodeB) から返された結果であり、取得できる情報が含まれています。

ビット番号 意味
000000 0 要素は一貫しています
000001 1 ノードは異なるドキュメント内にあります (または 1 つはドキュメントの外にあります)
000010 2 ノード B はノード A の前にあります
000100 4 ノード A はノード B に先行します
001000 8 ノード B にはノード A が含まれます
010000 16 ノード A にはノード B が含まれます
100000 32 ブラウザのプライベート使用

これは、可能性があることを意味します。結果は次のとおりです。同様:







ノード A に別のノード B が含まれ、B (16) が含まれ、B (4) より前にある場合、最終結果は数値 20 になります。ビットに何が起こるかを見てみると、理解が深まります。

000100 (4) 010000 (16) = 010100 (20)

これは、間違いなく、最も複雑な DOM API メソッドを理解するのに役立ちます。もちろん、彼の価値は十分に評価されるべきです。

DOMNode.compareDocumentPosition が Firefox と Opera で利用できるようになりました。ただし、IE でこれを実装するために使用できるトリックがいくつかあります。


// 位置の比較 - MIT ライセンス、John Resig
function ComparePosition(a, b){
return a.compareDocumentPosition
a.compareDocumentPosition(b) :
a.contains ?
( a != b && a.contains(b) && 16 )
( a != b && b.contains(a) && 8 )
( a.sourceIndex >= 0 && b.sourceIndex >= 0 ? (a.sourceIndex (a.sourceIndex > b.sourceIndex && 2) :
1) : 🎜> 0; >}
IE には、使用できるメソッドとプロパティがいくつか用意されています。まず、.contains() メソッド (前述のように) を使用して、contains (16) または is contains (8) の結果を取得します。また、IE には、ドキュメント内の要素の位置に対応するすべての DOM 要素の .sourceIndex 属性があります (例: document.documentElement.sourceIndex == 0)。この情報があるため、前面 (2) と背面 (4) の 2 つのcompareDocumentPosition パズルを完了できます。さらに、要素が現在のドキュメントにない場合、.sourceIndex は -1 になり、別の答え (1) が得られます。最後に、このプロセスを外挿することにより、要素がそれ自体と等しい場合、空のビットコード (0) が返されることがわかります。

この機能は Internet Explorer、Firefox、Opera で実行できます。ただし、Safari では機能が不完全です (contains() メソッドのみがあり、.sourceIndex 属性がないためです。取得できるのは Contains (16)、Contained (8) のみであり、他のすべての結果は切断を表す (1) を返します)。 。

PPK は、getElementsByTagNames メソッドを作成して新しい機能を利用できるようにする優れた例を提供します。これを新しいメソッドに適応させてみましょう:


//PPK quirksmode.org によるオリジナル
function getElementsByTagNames(list, elem) {
elem = elem || document; > var tagNames = list.split(','), results = [];

for ( var i = 0; i var tags = elem.getElementsByTagName( tagNames[i] );
for ( var j = 0; j results.push( tags[j] ); > return results.sort(function(a, b){
return 3 - (comparePosition(a, b) & 6); })
}
これを使用して、サイトのディレクトリを順番に作成できます:


getElementsByTagNames("h1, h2, h3");
Firefox と Opera はこのメソッドを実装するためにいくつかの取り組みを行っています。私は、前進を助けるためにさらに多くのブラウザが登場することを今でも楽しみにしています。
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Xiaomi Mi 14 ProでNFC機能を有効にする方法は? Xiaomi Mi 14 ProでNFC機能を有効にする方法は? Mar 19, 2024 pm 02:28 PM

現在、携帯電話の高性能化・高機能化が進み、ほとんどの携帯電話にはモバイル決済や本人認証などに便利なNFC機能が搭載されています。ただし、一部の Xiaomi 14Pro ユーザーは、NFC 機能を有効にする方法がわからないかもしれません。次に詳しくご紹介していきます。 Xiaomi 14ProでNFC機能を有効にする方法は?ステップ 1: 携帯電話の設定メニューを開きます。ステップ 2: 「接続と共有」または「ワイヤレスとネットワーク」オプションを見つけてクリックします。ステップ 3: [接続と共有] または [ワイヤレスとネットワーク] メニューで、[NFC と支払い] を見つけてクリックします。ステップ 4: 「NFC スイッチ」を見つけてクリックします。通常、デフォルトはオフです。ステップ 5: NFC スイッチ ページで、スイッチ ボタンをクリックしてオンに切り替えます。

Huawei Pocket2でTikTokをリモートで使用するにはどうすればよいですか? Huawei Pocket2でTikTokをリモートで使用するにはどうすればよいですか? Mar 18, 2024 pm 03:00 PM

画面の空中スライドは、Huawei mate60シリーズで高く評価されているHuaweiの機能であり、この機能は、携帯電話のレーザーセンサーとフロントカメラの3D深度カメラを使用して、画面を必要としない一連の機能を完了します。画面をタッチする機能は、たとえば、離れた場所から TikTok を使用することですが、Huawei Pocket 2 では、離れた場所から TikTok をどのように使用すればよいでしょうか? Huawei Pocket2で空中からスクリーンショットを撮るにはどうすればよいですか? 1. Huawei Pocket2 の設定を開きます。 2. [アクセシビリティ] を選択します。 3. クリックして [Smart Perception] を開きます。 4. [Air Swipe Screen]、[Air Screenshot]、[Air Press] スイッチをオンにするだけです。 5.使用するときは、画面から20〜40CM離れて立ち、手のひらを開いて、手のひらアイコンが画面に表示されるまで待つ必要があります。

iPhone 16 ProのCAD図面が公開され、2番目の新しいボタンが追加 iPhone 16 ProのCAD図面が公開され、2番目の新しいボタンが追加 Mar 09, 2024 pm 09:07 PM

iPhone 16 ProのCADファイルが公開されており、そのデザインは以前の噂と一致しています。昨年の秋、iPhone 15 Proにはアクションボタンが追加されましたが、今秋、Appleはハードウェアのサイズに若干の調整を行う予定のようです。キャプチャボタンの追加 噂によると、iPhone 16 Proには2つ目の新しいボタンが追加される可能性があり、昨年に続き2年連続で新しいボタンが追加されることになります。新しいキャプチャボタンはiPhone 16 Proの右下に設置されると噂されており、このデザインによりカメラ制御がより便利になり、アクションボタンも他の機能に使用できるようになると予想されています。このボタンは単なるシャッターボタンではなくなります。カメラに関しては現行iPより

WPS Word で行間を設定して文書をきれいにする方法 WPS Word で行間を設定して文書をきれいにする方法 Mar 20, 2024 pm 04:30 PM

弊社でよく使っているオフィスソフトはWPSですが、長文の編集ではフォントが小さすぎて見づらい場合が多いので、フォントや文書全体を調整します。たとえば、文書の行間を調整すると、文書全体が非常に鮮明になります。友達全員にこの操作手順を覚えてもらうことをお勧めします。今日はそれを共有します。具体的な操作手順は次のとおりです。ぜひ見てください。調整したいWPSテキストファイルを開き、[スタート]メニューの段落設定ツールバーに小さな行間設定アイコン(図の赤丸部分)が表示されます。 2. 行間隔設定の右下隅にある小さな逆三角形をクリックすると、対応する行間隔の値が表示され、行間隔の 1 ~ 3 倍を選択できます (図の矢印で示すように)。 3. または、段落を右クリックすると、段落が表示されます。

C言語とPHPの違いと比較分析 C言語とPHPの違いと比較分析 Mar 20, 2024 am 08:54 AM

C 言語と PHP の違いと比較分析 C 言語と PHP はどちらも一般的なプログラミング言語ですが、多くの点で明らかな違いがあります。この記事では、C 言語と PHP を比較分析し、具体的なコード例を通して両者の違いを説明します。 1. 構文と使用法: C 言語: C 言語はプロセス指向のプログラミング言語であり、主にシステムレベルのプログラミングと組み込み開発に使用されます。 C 言語の構文は比較的単純で低レベルであり、メモリを直接操作でき、効率的かつ柔軟です。 C言語はプログラマのプログラムの完全性を重視します

Xiaomi Mi 14 Ultra AIスマート画像拡張の使い方は? Xiaomi Mi 14 Ultra AIスマート画像拡張の使い方は? Mar 16, 2024 pm 12:37 PM

時代の進歩により、多くの人々の収入はますます高くなり、普段使用する携帯電話も頻繁に変更されますが、Xiaomi が最近発売した Xiaomi Mi 14 Ultra は、ユーザーにとって馴染みのあるものでしょう。快適でスムーズな体験を提供するために、新しい携帯電話には必然的に使用されない機能がたくさん出てきます。以下の使用法チュートリアルをご覧ください。 Xiaomi 14UltraAI スマート画像拡張の使用方法?まずXiaomi 14Ultraを開き、フォトアルバムに入り、拡大したい写真を選択して、フォトアルバム編集オプションに入ります。表示される選択範囲で [トリミング] [回転]、[トリミング] の順にクリックし、[スマート エキスパンド] をクリックします。最後に、自分のニーズに応じてイメージを拡張する方法を選択します。

PHP7.2と5のバージョンの長所と短所の比較と分析 PHP7.2と5のバージョンの長所と短所の比較と分析 Feb 27, 2024 am 10:51 AM

PHP7.2と5のメリットとデメリットの比較と分析。 PHPは非常に人気のあるサーバーサイドスクリプト言語であり、Web開発で広く使用されています。ただし、PHP は常に更新され、ニーズの変化に応じてさまざまなバージョンで改良されています。現在、PHP7.2 が最新バージョンですが、以前の PHP5 バージョンと比較して多くの注目すべき違いと改善点があります。この記事では、PHP7.2 と PHP5 のバージョンを比較し、それぞれの長所と短所を分析し、具体的なコード例を示します。 1. パフォーマンスPH

TrendX Research Institute: Merlin Chain プロジェクトの分析と生態学的インベントリ TrendX Research Institute: Merlin Chain プロジェクトの分析と生態学的インベントリ Mar 24, 2024 am 09:01 AM

3月2日の統計によると、ビットコインの第2層ネットワークMerlinChainのTVL総額は30億米ドルに達した。このうち、ビットコイン環境資産は90.83%を占め、15億9600万米ドル相当のBTCと4億400万米ドル相当のBRC-20資産が含まれている。先月、マーリンチェーンの合計 TVL はステーキング活動の開始から 14 日以内に 19 億 7,000 万米ドルに達し、昨年 11 月に開始され、同じく最新で同様に目を引くブラストを上回りました。 2月26日、MerlinChainエコシステムにおけるNFTの総額は4億2,000万米ドルを超え、イーサリアムに次いでNFT市場価値が最も高いパブリックチェーンプロジェクトとなった。プロジェクトの紹介 MerlinChain は OKX サポートです

See all articles