JS を解析してノードを取得し、互換性のためにノードをカプセル化する方法
#この記事では主に JS でのノードの取得方法と互換性カプセル化について紹介します。必要!ノードWeb ページのコンテンツはタグで構成されています (完全に正しいわけではありません)
Web ページのコンテンツはノードで構成されています
要素ノード属性ノード テキスト ノード コメント ノード ドキュメント ノード
ノードの 3 つの要素
- #ノード タイプ:nodeType
- ノード名:nodeName
- ノード値:nodeValue
节点类型(nodeType) 节点名称( nodeName) 节点值(nodeValue) 元素节点 1 标签名大写 null属性节点 2 属性名 属性值 文本节点 3 #text 文本 注释节点 8 #comment 注释内容 文档节点 9 #document null
子要素.parentNode
子要素の取得<div id = "box"> <!--宫崎骏--> <div>千与千寻</div> <div id="box2">哈儿的移动城堡</div> 龙猫 <div>悬崖上的金鱼姬</div> </div>
var box2 = document.getElementById("box2");console.log(box2.parentNode);
Parent element.appendChild(child element)
すべての子ノードを取得 <div id="box" style="width: 100px; height: 100px;">
<div id="box1" style="background-color: lightblue;">千与千寻</div>
<div id="box2">哈尔的移动城堡</div>
</div>
<script type="text/javascript">
var box = document.getElementById("box")
console.log(box.chilNodes);
</script>
ログイン後にコピー
1.兄弟要素と兄弟ノード兄弟ノードを取得<div id="box" style="width: 100px; height: 100px;"> <div id="box1" style="background-color: lightblue;">千与千寻</div> <div id="box2">哈尔的移动城堡</div> </div> <script type="text/javascript"> var box = document.getElementById("box") console.log(box.chilNodes); </script>
<div id = "box">
<!--宫崎骏-->
<div>千与千寻</div>
<div id="box2">哈儿的移动城堡</div>
龙猫
<div>悬崖上的金鱼姬</div>
</div>
ログイン後にコピー
取得要素:<div id = "box"> <!--宫崎骏--> <div>千与千寻</div> <div id="box2">哈儿的移动城堡</div> 龙猫 <div>悬崖上的金鱼姬</div> </div>
var box = document.getElementById("box");var box2 = document.getElementById("box2");
console.log(box2.previousSibling); // 文本节点
console.log(box2.nextSibling); // 文本节点
console.log(box2.previousElementSibling);
console.log(box2.nextElementSibling);
IE8 はノードを通じて兄弟要素のインテリジェンスを取得したいと考えています
@return node: 要素を返します。node
function getPreviousElement(ele) { // 能力检测 if(ele.previousElementSibling) { // 谷歌火狐 return ele.previousElementSibling; } else { // IE8 // 获取上一个节点 : null 元素 文本 注释 var node = ele.previousSibling; // 循环次数不确定 // 1. node必须存在, 不是null, 2. node不是元素节点 while(node != null && node.nodeType != 1) { node = node.previousSibling } // node == null 或者 node.nodeType == 1 return node; } } console.log(getPreviousElement(li2));
Parent element.firstChild 最初の子要素を取得します:
Parent element.firstElementChild
var box = document.getElementById("box");console.log(box.firstChild);console.log(box.firstElementChild);
最初の子要素の互換性パッケージを取得します
function getFirstElementChild(ele) {
if (ele.firstElementChild != undefined) {
return ele.firstElementChild;
} else {
var nodeFirst = ele.firstChild;
while (nodeFirst && nodeFirst.nodeType == 1) {
nodeFirst = nodeFirst.nextSibling;
}
return nodeFirst;
}
}
console.log(ul.firstElementChild);
ログイン後にコピー
3. 最後の子ノードと子要素を取得します最後の子ノードを取得し、子要素最後の A 子ノードを取得します: function getFirstElementChild(ele) { if (ele.firstElementChild != undefined) { return ele.firstElementChild; } else { var nodeFirst = ele.firstChild; while (nodeFirst && nodeFirst.nodeType == 1) { nodeFirst = nodeFirst.nextSibling; } return nodeFirst; } } console.log(ul.firstElementChild);
Parent element.lastChild 最後の子要素を取得します:
Parent element.lastElementChild
var box = document.getElementById("box");console.log(box.lastChild);console.log(box.lastElementChild);
function firstElement(ele) {
if (ele.firstElementChild) {//谷歌和火狐
return ele.firstElementChild;
}
else {//IE8
var node = ele.firstChild;
while (node != null && node.nodeType != 1) {
node = node.nextSibling;
}
return node;
}
}
console.log(firstElement(ul))
ログイン後にコピー
4. クローン ノードクローン ノード: function firstElement(ele) { if (ele.firstElementChild) {//谷歌和火狐 return ele.firstElementChild; } else {//IE8 var node = ele.firstChild; while (node != null && node.nodeType != 1) { node = node.nextSibling; } return node; } } console.log(firstElement(ul))
Element.cloneNode(parameter) パラメーター:
パラメータがある場合:
- パラメータが true の場合、ディープ クローン作成を意味します。このタグとタグ内のすべてのコンテンツをクローンできます。
- パラメータが false の場合、浅い複製を意味します。現在のタグのみが複製され、このタグのコンテンツは複製されません。 #パラメータはありません。デフォルトは false です。
<div id="box"> I'm a big box <h1>我是标题</h1> </div>
var box = document.getElementById("box");var Newbox = box.cloneNode(true)console.log(New);
- 複製されたノードはメモリ内に複製されるだけで、ページには追加されません。手動でのみ追加できます
- クローン huibaid もクローンされます。 以前は
- ページIDの一意性を維持するために、クローンされた要素のIDを変更する必要がありました
Newbox.id = "Newbox"
タオバオの場合、QR コードを非表示にする
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>关闭二维码</title> <style type="text/css"> #box{ width: 94px; height: 92px; margin: 30px auto; position: relative; } #x{ width: 14px; height: 14px; line-height: 14px; border: 1px solid #D9D9D9; color: #D6D6D6; text-align: center; position: absolute; top: 0; left: -15px; } #img{ width: 76px; height: 90px; background-image: url(img/erweima.png); } </style> </head> <body> <div id="box"> <div id="x">x</div> <div id="img"></div> </div> <script type="text/javascript"> var x = document.getElementById("x") x.onclick = function(){ this.parentNode.style.display = 'none'; } </script> </body> </html>
関連する推奨事項:【
JavaScript ビデオ チュートリアル以上がJS を解析してノードを取得し、互換性のためにノードをカプセル化する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









WebSocket と JavaScript を使用してオンライン音声認識システムを実装する方法 はじめに: 技術の継続的な発展により、音声認識技術は人工知能の分野の重要な部分になりました。 WebSocket と JavaScript をベースとしたオンライン音声認識システムは、低遅延、リアルタイム、クロスプラットフォームという特徴があり、広く使用されるソリューションとなっています。この記事では、WebSocket と JavaScript を使用してオンライン音声認識システムを実装する方法を紹介します。

WebSocketとJavaScript:リアルタイム監視システムを実現するためのキーテクノロジー はじめに: インターネット技術の急速な発展に伴い、リアルタイム監視システムは様々な分野で広く利用されています。リアルタイム監視を実現するための重要なテクノロジーの 1 つは、WebSocket と JavaScript の組み合わせです。この記事では、リアルタイム監視システムにおける WebSocket と JavaScript のアプリケーションを紹介し、コード例を示し、その実装原理を詳しく説明します。 1.WebSocketテクノロジー

JavaScript と WebSocket を使用してリアルタイム オンライン注文システムを実装する方法の紹介: インターネットの普及とテクノロジーの進歩に伴い、ますます多くのレストランがオンライン注文サービスを提供し始めています。リアルタイムのオンライン注文システムを実装するには、JavaScript と WebSocket テクノロジを使用できます。 WebSocket は、TCP プロトコルをベースとした全二重通信プロトコルで、クライアントとサーバー間のリアルタイム双方向通信を実現します。リアルタイムオンラインオーダーシステムにおいて、ユーザーが料理を選択して注文するとき

WebSocket と JavaScript を使用してオンライン予約システムを実装する方法 今日のデジタル時代では、ますます多くの企業やサービスがオンライン予約機能を提供する必要があります。効率的かつリアルタイムのオンライン予約システムを実装することが重要です。この記事では、WebSocket と JavaScript を使用してオンライン予約システムを実装する方法と、具体的なコード例を紹介します。 1. WebSocket とは何ですか? WebSocket は、単一の TCP 接続における全二重方式です。

JavaScript と WebSocket: 効率的なリアルタイム天気予報システムの構築 はじめに: 今日、天気予報の精度は日常生活と意思決定にとって非常に重要です。テクノロジーの発展に伴い、リアルタイムで気象データを取得することで、より正確で信頼性の高い天気予報を提供できるようになりました。この記事では、JavaScript と WebSocket テクノロジを使用して効率的なリアルタイム天気予報システムを構築する方法を学びます。この記事では、具体的なコード例を通じて実装プロセスを説明します。私たちは

JavaScript チュートリアル: HTTP ステータス コードを取得する方法、特定のコード例が必要です 序文: Web 開発では、サーバーとのデータ対話が頻繁に発生します。サーバーと通信するとき、多くの場合、返された HTTP ステータス コードを取得して操作が成功したかどうかを判断し、さまざまなステータス コードに基づいて対応する処理を実行する必要があります。この記事では、JavaScript を使用して HTTP ステータス コードを取得する方法を説明し、いくつかの実用的なコード例を示します。 XMLHttpRequestの使用

使用法: JavaScript では、insertBefore() メソッドを使用して、DOM ツリーに新しいノードを挿入します。このメソッドには、挿入される新しいノードと参照ノード (つまり、新しいノードが挿入されるノード) の 2 つのパラメータが必要です。

JavaScript は Web 開発で広く使用されているプログラミング言語であり、WebSocket はリアルタイム通信に使用されるネットワーク プロトコルです。 2 つの強力な機能を組み合わせることで、効率的なリアルタイム画像処理システムを構築できます。この記事では、JavaScript と WebSocket を使用してこのシステムを実装する方法と、具体的なコード例を紹介します。まず、リアルタイム画像処理システムの要件と目標を明確にする必要があります。リアルタイムの画像データを収集できるカメラ デバイスがあるとします。
