ホームページ >ウェブフロントエンド >jsチュートリアル >querySelector を二度と使用しない理由。
JavaScript エコシステムは常に進化しており、将来の新たな波が到来する時期が来ています。
jQuery が document.querySelector() および document.querySelectorAll() としてブラウザーに組み込まれたとき、私たちは皆、それを気に入りました。 DOM メソッドを使用すると、DOM へのアクセスが大幅に向上します。
最近、document.querySelector() と document.querySelectorAll() の両方を使用することは遠い過去に固執しており、JavaScript の多くの魅力的な機能が欠けていることが実際に証明された経験がありました。
document.querySelector() と document.querySelectorAll() を使用すると、DOM を分解できず、DOM に一貫してアクセスでき、複数の選択が簡素化され、入力の難しさが軽減されます。さて、あなたがすでに欠けているものをすべて認識できるように、さらに深く掘り下げてみましょう。
でも待ってください! querySelector() と querySelectorAll() が何であるかをよく理解しておらず、さらに詳しく知りたい場合。以下のビデオチュートリアルをご覧ください: JavaScript DOM 操作
document.querySelector() と document.querySelectorAll() は、DOM の選択において一貫性がありません。 1 つはターゲット セレクターの最初のインスタンスを選択し、もう 1 つはターゲット セレクターのすべてのインスタンスを選択します。つまり、1 つは個々の要素の選択に使用され、もう 1 つは要素のグループの選択に使用されます。
したがって、両方を同じ意味で使用することはできません。何を選択するかに応じて、次々と切り替えを行う必要があります。
// Select the first element of the class .post const post = document.querySelector('.post'); // Select all elements of the class .post const posts = document.querySelectorAll('.post');
それでは、より良い方法を紹介しましょう。 $select()
に付属する koras.jsx という UI ライブラリを構築しました。
これは、JavaScript の document.querySelector() と document.querySelectorAll() の両方の代わりに使用できます。以下にその使用方法を示します。
//select all instances of class .post const posts = $select('.post'); //select the first instance of class post const firstPost = $select('.post[0]'); //Doing the same with querySelector const posts = document.querySelectorAll('.post'); const firstPost = posts[0];
それはなんてクールなんでしょう?そして、これは document.querySelector() と document.querySelectorAll() の両方のユースケースで機能します。
グループ化された要素の中から任意の位置の要素を選択できます。
//select 6th instance of class post $select('.post[5]') //select 7th instance of div elements $select('div[6]')
次のように $select() を使用して要素を削除できます。
//Delete only the instance of .post with index is equal to 2 $select('.post[delete|i=2]'); //delete all instances of .post with index greater than 2 $select('.post[delete|i>2]');
次のように $select() を使用して要素に属性を追加できます。
$select('.post[add|class=hidden]'); $select('.post[add|style=1px solid red]'); $select('.post[add|id=2]'); $select('.post[add|class=flex bold]')
次のように $select() を使用して要素から属性を削除できます。
$select('.post[remove|class=hidden]'); $select('.post[remove|id]'); $select('.post[remove|class=flex bold]') $select('.post[remove|style]');
DOM の構造化は es6 に同梱されている機能の 1 つですが、document.querySelector() および document.querySelectorAll() で選択された要素を構造化できないことに驚かれるでしょう。
// Select the first element of the class .post const post = document.querySelector('.post'); // Select all elements of the class .post const posts = document.querySelectorAll('.post');
//select all instances of class .post const posts = $select('.post'); //select the first instance of class post const firstPost = $select('.post[0]'); //Doing the same with querySelector const posts = document.querySelectorAll('.post'); const firstPost = posts[0];
見えますか? document.querySelectAll() は DOM の構造化をサポートしていません。これは、DOM の構造化を逃していることを意味します。いいえ!それはまったくクールではないので、$select() を使い始める必要があります。
document.querySelect() または document.querySelectorAll() を使用すると、DOM の構造化がサポートされていないため、不必要に繰り返す必要があり、JavaScript コードの保守が少し面倒になります。
//select 6th instance of class post $select('.post[5]') //select 7th instance of div elements $select('div[6]')
//Delete only the instance of .post with index is equal to 2 $select('.post[delete|i=2]'); //delete all instances of .post with index greater than 2 $select('.post[delete|i>2]');
それがどれほど反復的であり、コードベースを大規模に保守するのが少し面倒になることがわかりますか?
ほら、以下のように $select() を使って同じことを簡単に行うことができます:
$select('.post[add|class=hidden]'); $select('.post[add|style=1px solid red]'); $select('.post[add|id=2]'); $select('.post[add|class=flex bold]')
document.querySelector() を使用すると、DOM の構造化と複数選択がサポートされているため、$select() に比べてバグが隠れる表面積が増える傾向があります。
$select('.post[remove|class=hidden]'); $select('.post[remove|id]'); $select('.post[remove|class=flex bold]') $select('.post[remove|style]');
$select() は、要素を選択するために書き込むコードの行数を減らし、バグが隠れる表面積を減らします。つまり、$select() を使用すると、比較的早くバグが発見される可能性が高くなります。
querySelector で選択された要素は forEach でのみ機能し、map()、filter()、および co では機能しません。
$select() は、不必要な繰り返しと大規模な複雑さを引き起こす可能性があるいくつかの回避策を必要とする document.querySelectorAll() とは異なり、デフォルトですべての配列メソッドで動作します。
保守性は常に、使いやすさ、簡潔さ、一貫性を中心に展開されます。簡潔で一貫性があり、使いやすいコードベースは保守しやすい傾向があります。特にバグを修正したり機能を構築したりするときには、注目すべき表面積が増えるため、反復的で冗長なコードを維持するのは面倒です。
可能な限り JavaScript の配布を減らすのが経験則であり、$select() を使用すると、DOM 選択を処理しながらそれが可能になります。 $select() は、より簡潔で繰り返しが少ないため、大規模な場合は document.querySelector() および document.querySelectorAll() よりも推奨されます。選択する要素が増えるほど、$select() で選択を繰り返す回数が減ります。
DOM は NodeList を想定しているため、$select() によって生成された要素の配列を element.append(arrayGeneratedBy$Select) のような別の要素に追加することはできません。
それでも、$select() に 2 番目のパラメーターとして false を渡すことで、そのスーパーパワーをすべて無効にするように指示できます。
const [posts, comments] = document.querySelectorAll('.post, .comment');
これで、追加可能および先頭に追加可能な通常の DOM NodeList[] が返されます。
$select() が document.querySelect() または document.querySelectorAll() でできるすべてのことを実行できるかどうか興味があるかもしれません。はい!彼らがやることは何でもできるのです。 $select() はすべてを実行できます。 tagor CSS セレクターを使用し、query.querySelector() で実行できる他のすべてのことを実行できます。
querySelector() または querySelectorAll() は $select() よりも平均約 1 ミリ秒 高速であると主張することもできますが、$select() は次のようにしてそれを取り戻します。大規模な関心。
querySelector の使用方法を理解することで、$select() と同様に役立つものを構築する機会が得られるため、querySelector の使用方法を学ぶ必要があります。 $select() がどのように機能するかを本当に理解しているので、$select() を構築できます。
それに関するチュートリアルを作成しました。以下を確認してください: JavaScript DOM 操作
DOM の構造化をサポートし、配列ベースの選択を可能にすることで、$select() がツールキットに追加される価値があることがわかります。コードの読みやすさが向上するだけでなく、バグが発生する領域が最小限に抑えられるため、デバッグプロセスがより簡単になります。
保守性、簡潔さ、一貫性を追求する中で、$select() は DOM 選択の有力な選択肢として浮上し、JavaScript 開発の進化の一歩を示しています。
進化する JavaScript エコシステムに適応し続ける中で、$select() のようなツールを採用することで、コードをより簡潔に、読みやすく、保守しやすくすることができます。
以上がquerySelector を二度と使用しない理由。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。