目次
プロパティを「クリックして」に設定します。 NodeList.jsは、NodeListの各ノードに対してこれを実行します。とても賢いですよね?
nodeList.jsアレイメソッドのサポート
pushおよびunshift
メソッド:
callメソッドでは、要素固有のメソッドを呼び出すことができます(たとえば、ビデオ要素で
itemメソッドは、jQueryの
owner属性は、jqueryの
ノデリストとHTMLCollectionの違いは何ですか?
jQueryセレクターは、通常の要素ではなくprevobjectを返すのはなぜですか?
ノデリストをループする方法は?
jQueryでの.prev()メソッドの使用は何ですか?
jQueryは2022年にまだ関連していますか?
ノデリストから特定のノードを選択する方法は?

jQueryの膨満感を失います

Feb 19, 2025 am 08:27 AM

Lose the jQuery Bloat ­

コアポイント

  • nodeList.jsは、jQueryのDOM操作の代替として、同様の機能を提供しますが、(圧縮後4K)、ネイティブブラウザーAPIの改善を利用します。

  • jQueryとは異なり、nodelist.jsはノードアレイを単一ノードとして扱い、クリーナーコードを有効にし、ノーデリストオブジェクト操作を容易にします。

  • nodeList.jsには、属性を設定および取得し、要素固有の方法を呼び出し、ノデリストのノードへのアクセスを含む特別な方法が含まれています。 prevObject owner

  • nodeList.jsは、特定のバージョン(Firefox 6、Safari 5.0.5、Chrome 6、IE 9、Opera 11.6)の後に主流のブラウザと互換性があり、ブラウザーによって追加された新しいメソッド/プロパティが含まれるように自動的に更新されます。
  • p.tip { バックグラウンドカラー:RGBA(128,128,128,0.05); Border-Top-Right-Radius:5px; 国境圏 - 右とradius:5px; パディング:15px 20px; 国境左:10pxソリッドRGBA(128,128,128,075); }

  • 近年、jQueryはWeb上の事実上のJavaScriptライブラリになりました。多くのクロスブラウザーの矛盾を削除し、クライアントスクリプトに人気のある構文砂糖の層を追加します。抽象化処理の主な問題の1つはDOM操作ですが、jQueryの出現以来、ネイティブブラウザーAPIが大幅に改善されており、「おそらくJqueryを必要としない」という概念が人気がありました。

理由は次のとおりです

jQueryには、必要または使用していない多くの機能が含まれています(したがって、巨大であることは不要です)。

    jQueryは、あまりにも多くの人々のためにあまりにも多くの機能を担当します。一般に、小さなライブラリはいくつかのタスクをより良く実行できます。
  1. dom操作の観点から、ブラウザAPIはjQueryのほとんどの関数を実行できるようになりました。
  2. ブラウザAPIは、たとえば
  3. の代わりに
  4. を使用するなど、より同期しています。
  5. addEventListener attachEvent問題は何ですか?
問題は、domにネイティブ(または純粋な)javaScriptを使用することは、jqueryと比較して面倒である可能性があることです。これは、より冗長なコードを作成し、ブラウザの役に立たないノデリストを処理する必要があるためです。

まず、MDNのノデリストの定義を見てみましょう:

NodeListオブジェクトは、ノードのコレクションであり、

メソッドおよび

メソッドによって返されるものです。

Node.childNodesダイナミクスノデリストが時々あります(混乱する可能性があります):document.querySelectorAll

場合によっては、NodeListは動的なコレクションです。つまり、DOMの変更がコレクションに反映されています。たとえば、

は動的です。

これは、動的で静的なものがわからないため、問題になる可能性があります。 NodeListから各ノードを削除し、ノデリストが空であるかどうかを確認しない限り。空の場合、動的なノデリストがあります(それはただの悪い考えです)。 Node.childNodesさらに、ブラウザは、これらのノデリストオブジェクトを操作するための有用な方法を提供しません。

たとえば、残念ながら、

を使用してノードをループすることはできません。

したがって、forEach次のことを行う必要があります

var nodes = document.querySelectorAll('div');
nodes.forEach(function(node) {
  // do something
});
// 错误:nodes.forEach 不是函数
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
または「ハック」のみを使用することさえあります:

var nodes = document.querySelectorAll('div');
for(var i = 0, l = nodes.length; i < l; i++) {
  // do something with nodes[i]
}
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ブラウザのネイティブノデリストには、1つの方法しかありません。 Indexを介してNodeListからノードを返します。アレイを使用するようにノードにアクセスできる場合(

を使用)、それは完全に役に立たない:

[].forEach.call(document.querySelectorAll('div'), function(node) {
    // do something
});
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー

これは、nodelist.jsが登場する場所です。JQUERYを使用してブラウザネイティブAPIを使用してDOMを簡単に操作できますが、4K圧縮サイズのみが必要です。 item array[index]

solution
var nodes = document.querySelectorAll('div');
nodes.item(0) === nodes[0]; // true
ログイン後にコピー
ログイン後にコピー

Nodelist.jsを作成しました。なぜなら、ネイティブDom APIを使用しているが、それらをより簡潔にしたいので、コードを作成するときに多くの冗長性を減らします(ループなど)。

nodeList.jsは、単一のノードであるかのようにノードの配列(つまり、ノデリスト)を操作できるネイティブDom APIのラッパーです。これにより、ブラウザのネイティブNodeListオブジェクトよりも多くの機能が得られます。

これが良いと思われる場合は、公式のGithubリポジトリからnodelist.jsのコピーを入手し、このチュートリアルの残りの部分を読み続けてください。

使用法:

domノードの選択は簡単です:

//ノデリストに戻ります

この方法は、バックグラウンドで使用されています

$$(selector);

しかし、jqueryと比較してどうですか?

この質問をしてくれてうれしいです。ネイティブJS、jQuery、およびnodelist.jsを比較しましょう。 querySelectorAll(selector)

3つのボタンがあるとします:

各ボタンのテキストを「私をクリックする」に変更しましょう。

ネイティブjs:

jquery:

var buttons = document.querySelectorAll('button'); // 返回浏览器无用的 NodeList
for(var i = 0, l = buttons.length; i < l; i++) {
  buttons[i].textContent = 'Click Me';
}
ログイン後にコピー
ログイン後にコピー

nodelist.js:

$('button').text('Click Me');
ログイン後にコピー
ログイン後にコピー

ここでは、nodeList.jsがノデリストを単一のノードとして効果的に扱うことができることがわかります。つまり、ノデリストを参照して、

プロパティを「クリックして」に設定します。 NodeList.jsは、NodeListの各ノードに対してこれを実行します。とても賢いですよね?

メソッドチェーン(jQueryと同様)が必要な場合は、次のことを行います。これは、ノデリストへの参照を返します。
$$('button').textContent = 'Click Me';
ログイン後にコピー
ログイン後にコピー

さあ、各ボタンにクリックイベントリスナーを追加しましょう:textContent

ネイティブjs:

$$('button').set('textContent', 'Click Me');
ログイン後にコピー
ログイン後にコピー

jquery:

nodelist.js:
var buttons = document.querySelectorAll('button'); // 返回浏览器无用的 NodeList
for(var i = 0, l = buttons.length; i < l; i++) {
  buttons[i].addEventListener('click', function() {
    this.classList.add('clicked');
  });
}
ログイン後にコピー

さて、jqueryの
$('button').on('click', function() {
  $(this).addClass('click');
  // 或将 jQuery 与原生混合使用 `classList`:
  this.classList.add('clicked');
});
ログイン後にコピー
方法はかなり良いです。私のライブラリはブラウザのネイティブDOM API(したがって

)を使用していますが、それは私たちがこの方法のエイリアスを作成することを妨げません:

$$('button').addEventListener('click', function() {
  this.classList.add('clicked');
});
ログイン後にコピー

悪くない!これは、独自の方法を追加する方法を示しています

var nodes = document.querySelectorAll('div');
nodes.forEach(function(node) {
  // do something
});
// 错误:nodes.forEach 不是函数
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー

nodeList.jsアレイメソッドのサポート

nodeList.jsはArray.prototypeから継承しますが、直接ではありません。いくつかの方法が変更されているため、ノデリスト(ノードの配列)でそれらを使用することは理にかなっています。

pushおよびunshift

たとえば、

およびpushメソッドはパラメーターとしてノードのみをとることができます。そうしないと、エラーがスローされます。 unshift

したがって、ノデリストを返してメソッドチェーンを許可します。つまり、JavaScriptのネイティブ
var nodes = document.querySelectorAll('div');
for(var i = 0, l = nodes.length; i < l; i++) {
  // do something with nodes[i]
}
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
またはメソッドとは異なります。 NodeListの長さが必要な場合は、プロパティを使用する必要があります。

これら2つのメソッドは、JavaScriptのネイティブ配列メソッドのように、ノデリストを変更します。 push unshift Array#pushArray#unshift length

メソッドは、パラメーターとして以下を受け入れます。

は再帰的な方法なので、これらの配列は私たちが望むほど深く、平らになる可能性があります。ただし、通過した配列の要素がノード、ノデリスト、またはhtmlCollectionでない場合、エラーが発生します。 concat

javascriptのconcatメソッドと同様に、新しいノデリストを返します。

[].forEach.call(document.querySelectorAll('div'), function(node) {
    // do something
});
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー

concat

concatArray#concat

popおよびshiftメソッドの両方がオプションのパラメーターを使用して、ノードリストからポップまたはシフトするノードの数を示します。 JavaScriptのネイティブmapまたはsliceとは異なり、後者は常にパラメーターとして渡されるものに関係なく、常に配列内の要素をポップアップ表示またはシフトします。 filter

マッピングされた各値がノードである場合、

メソッドはノーデリストを返します。

popshiftおよびArray#popメソッドは、実際の配列で行うのと同じことを行いますが、ノデリストを返します。 Array#shift

nodeList.jsは

から直接継承しないため、nodeList.jsをロードするときにmapにメソッドを追加すると、継承されません。

ここで、Nodelist.jsの残りの配列メソッドを表示できます。 slice filter特別な方法

nodeList.jsには、4つの一意の方法と、Array.prototypeと呼ばれるプロパティがあります。 Array.prototype

および

メソッド:

ownerいくつかの要素には、そのタイプの要素に固有の属性があります(たとえば、アンカータグのprevObject属性)。これが、

が定義されていない理由です。これは、ノデリストのすべての要素に継承されたプロパティではないためです。これは、これらのプロパティにアクセスするために

メソッドを使用する方法です。

var nodes = document.querySelectorAll('div');
nodes.forEach(function(node) {
  // do something
});
// 错误:nodes.forEach 不是函数
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー

setメソッドを使用して、各要素のこれらのプロパティを設定できます。

また、
var nodes = document.querySelectorAll('div');
for(var i = 0, l = nodes.length; i < l; i++) {
  // do something with nodes[i]
}
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー

ノデリストを返して、メソッドチェーンを許可します。 setなどで使用できます(両方とも同等):textContent

[].forEach.call(document.querySelectorAll('div'), function(node) {
    // do something
});
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
1回の呼び出しに複数のプロパティを設定することもできます。

上記のすべての操作は、任意の属性を使用して実行できます。
var nodes = document.querySelectorAll('div');
nodes.item(0) === nodes[0]; // true
ログイン後にコピー
ログイン後にコピー

style

メソッド
var buttons = document.querySelectorAll('button'); // 返回浏览器无用的 NodeList
for(var i = 0, l = buttons.length; i < l; i++) {
  buttons[i].textContent = 'Click Me';
}
ログイン後にコピー
ログイン後にコピー

callメソッドでは、要素固有のメソッドを呼び出すことができます(たとえば、ビデオ要素で

):

call pause

メソッド
$('button').text('Click Me');
ログイン後にコピー
ログイン後にコピー

itemメソッドは、jQueryの

メソッドに相当します。インデックスを通過するノードのみを含むノデリストを返します:

item eq

属性
$$('button').textContent = 'Click Me';
ログイン後にコピー
ログイン後にコピー

owner属性は、jqueryの

に相当します。

ownerprevObjectスタイルアレイを返し、

はマッピングされたノデリストを返します。
$$('button').set('textContent', 'Click Me');
ログイン後にコピー
ログイン後にコピー

nodeList.js互換性btns.style owner私のライブラリは、以下に説明するように、すべての主要な新しいブラウザと互換性があります。 style

browser

バージョンfirefox6 safari 5.0.5 chrome6 < 🎜<🎜<🎜<🎜<🎜<🎜ie 9 opera 11.6 < 結論 これで、最終的に便利なノデリストオブジェクトを使用できます! 約4Kの圧縮サイズの場合、上記のすべてを取得します。これについては、nodeList.jsのgithubリポジトリで学ぶことができます。 nodelist.jsは依存関係としてブラウザを使用するため、アップグレードは必要ありません。ブラウザが新しいメソッド/属性をDOM要素に追加するたびに、これらのメソッド/属性をnodeList.jsを介して自動的に使用できます。これはすべて、心配する必要がある唯一の非推測はブラウザ削除方法だけであることを意味します。これらは通常、Webを壊すことができないため、非常に低い使用方法です。 それで、あなたはどう思いますか?このライブラリを使用することを検討しますか?重要な機能はありませんか?以下のコメントであなたのコメントを聞いてみたいです。 nodeList.js

を使用したDOM操作に関するよくある質問

ノデリストとHTMLCollectionの違いは何ですか?

ノデリストとhtmlCollectionはどちらもノードコレクションです。それらの主な違いは、ノデリストが任意のノードタイプを含めることができることですが、HTMLCollectionは要素ノードのコレクションです。 HTMLCollectionも動的です。つまり、ドキュメント構造が変更されると自動的に更新されます。一方、NodeListは静的であり、ドキュメントの変更を反映するために更新しません。

ノデリストを配列に変換する方法は?

メソッドまたは拡張演算子を使用して、ノデリストをアレイに変換できます。それを行う方法は次のとおりです
var nodes = document.querySelectorAll('div');
nodes.forEach(function(node) {
  // do something
});
// 错误:nodes.forEach 不是函数
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー

jQueryセレクターは、通常の要素ではなくprevobjectを返すのはなぜですか?

JQueryのチェーンメカ​​ニズムは、変更を加える前に以前のオブジェクトを保存することにより機能します。これにより、.end()メソッドを使用して以前の状態に復元できます。実際のDOM要素を取得したい場合は、.get()メソッドまたは配列表記を使用できます。

ノデリストをループする方法は?

for loop、for ... of loop、またはforEach()メソッドを使用して、ノデリストをループすることができます。以下は、forループを使用した例です:

var nodes = document.querySelectorAll('div');
for(var i = 0, l = nodes.length; i < l; i++) {
  // do something with nodes[i]
}
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー

jQueryでの.prev()メソッドの使用は何ですか?

jQueryの.prev()メソッドは、前の兄弟のすぐ隣の選択した要素を選択するために使用されます。セレクターが提供されている場合、以前の兄弟要素は、セレクターが一致している場合にのみ取得されます。

jQueryは2022年にまだ関連していますか?

jQueryは発売時のゲームチェンジャーでしたが、最新のJavaScriptエコシステムは大幅に変化しました。 JQueryを人気にする機能の多くは、JavaScript自体に組み込まれています。ただし、JQueryは依然として広く使用され、維持されており、一部のプロジェクトには適した選択かもしれません。

ノデリストから特定のノードを選択する方法は?

配列表記またはitem()メソッドを使用して、NodeListから特定のノードを選択できます。それを行う方法は次のとおりです

[].forEach.call(document.querySelectorAll('div'), function(node) {
    // do something
});
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ノデリストのメソッドを使用、フィルター、および削減できますか?

ノデリストは配列ではないため、マップ、フィルター、削減などのメソッドはありません。ただし、ノデリストを配列に変換してから、これらのメソッドを使用できます。

QuerySelectorとQuerySelectorallの違いは何ですか?

指定されたCSSセレクターに一致するドキュメントの最初の要素を返し、querySelectorはCSSセレクターに一致するすべての要素のノデリストを返します。 querySelectorAll

ノデリストが空であるかどうかを確認するにはどうすればよいですか?

プロパティをチェックして、Nodelistが空であるかどうかを確認できます。長さが0の場合、ノデリストは空です。それを行う方法は次のとおりです length

以上がjQueryの膨満感を失いますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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)

フロントエンドのサーマルペーパーレシートのために文字化けしたコード印刷に遭遇した場合はどうすればよいですか? フロントエンドのサーマルペーパーレシートのために文字化けしたコード印刷に遭遇した場合はどうすればよいですか? Apr 04, 2025 pm 02:42 PM

フロントエンドのサーマルペーパーチケット印刷のためのよくある質問とソリューションフロントエンド開発におけるチケット印刷は、一般的な要件です。しかし、多くの開発者が実装しています...

javascriptの分解:それが何をするのか、なぜそれが重要なのか javascriptの分解:それが何をするのか、なぜそれが重要なのか Apr 09, 2025 am 12:07 AM

JavaScriptは現代のWeb開発の基礎であり、その主な機能には、イベント駆動型のプログラミング、動的コンテンツ生成、非同期プログラミングが含まれます。 1)イベント駆動型プログラミングにより、Webページはユーザー操作に応じて動的に変更できます。 2)動的コンテンツ生成により、条件に応じてページコンテンツを調整できます。 3)非同期プログラミングにより、ユーザーインターフェイスがブロックされないようにします。 JavaScriptは、Webインタラクション、シングルページアプリケーション、サーバー側の開発で広く使用されており、ユーザーエクスペリエンスとクロスプラットフォーム開発の柔軟性を大幅に改善しています。

誰がより多くのPythonまたはJavaScriptを支払われますか? 誰がより多くのPythonまたはJavaScriptを支払われますか? Apr 04, 2025 am 12:09 AM

スキルや業界のニーズに応じて、PythonおよびJavaScript開発者には絶対的な給与はありません。 1. Pythonは、データサイエンスと機械学習でさらに支払われる場合があります。 2。JavaScriptは、フロントエンドとフルスタックの開発に大きな需要があり、その給与もかなりです。 3。影響要因には、経験、地理的位置、会社の規模、特定のスキルが含まれます。

JavaScriptを使用して、同じIDを持つArray要素を1つのオブジェクトにマージする方法は? JavaScriptを使用して、同じIDを持つArray要素を1つのオブジェクトにマージする方法は? Apr 04, 2025 pm 05:09 PM

同じIDを持つ配列要素をJavaScriptの1つのオブジェクトにマージする方法は?データを処理するとき、私たちはしばしば同じIDを持つ必要性に遭遇します...

JavaScriptは学ぶのが難しいですか? JavaScriptは学ぶのが難しいですか? Apr 03, 2025 am 12:20 AM

JavaScriptを学ぶことは難しくありませんが、挑戦的です。 1)変数、データ型、関数などの基本概念を理解します。2)非同期プログラミングをマスターし、イベントループを通じて実装します。 3)DOM操作を使用し、非同期リクエストを処理することを約束します。 4)一般的な間違いを避け、デバッグテクニックを使用します。 5)パフォーマンスを最適化し、ベストプラクティスに従ってください。

Shiseidoの公式Webサイトのように、視差スクロールと要素のアニメーション効果を実現する方法は?
または:
Shiseidoの公式Webサイトのようにスクロールするページを伴うアニメーション効果をどのように実現できますか? Shiseidoの公式Webサイトのように、視差スクロールと要素のアニメーション効果を実現する方法は? または: Shiseidoの公式Webサイトのようにスクロールするページを伴うアニメーション効果をどのように実現できますか? Apr 04, 2025 pm 05:36 PM

この記事の視差スクロールと要素のアニメーション効果の実現に関する議論では、Shiseidoの公式ウェブサイト(https://www.shisido.co.co.jp/sb/wonderland/)と同様の達成方法について説明します。

Console.log出力の違い結果:なぜ2つの呼び出しが異なるのですか? Console.log出力の違い結果:なぜ2つの呼び出しが異なるのですか? Apr 04, 2025 pm 05:12 PM

Console.log出力の違いの根本原因に関する詳細な議論。この記事では、Console.log関数の出力結果の違いをコードの一部で分析し、その背後にある理由を説明します。 �...

フロントエンド開発でVSCodeと同様に、パネルドラッグアンドドロップ調整機能を実装する方法は? フロントエンド開発でVSCodeと同様に、パネルドラッグアンドドロップ調整機能を実装する方法は? Apr 04, 2025 pm 02:06 PM

フロントエンドのVSCodeと同様に、パネルドラッグアンドドロップ調整機能の実装を調べます。フロントエンド開発では、VSCODEと同様のVSCODEを実装する方法...

See all articles