国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

ホームページ ウェブフロントエンド jsチュートリアル jQueryメソッドのネイティブJavaScript同等物:DOMとフォーム

jQueryメソッドのネイティブJavaScript同等物:DOMとフォーム

Feb 23, 2025 am 08:59 AM

Native JavaScript Equivalents of jQuery Methods: the DOM and Forms

コアポイント

  • jQueryは、アプリケーションの開発よりも長(zhǎng)くjqueryのようなライブラリをサポートする必要がある開発者にとって便利なツールです。ただし、他のほとんどのケースでは、Native JavaScriptを使用することは、jQueryのような大きなライブラリを読み込む必要がないため、より効率的です。
  • domセレクターやDOM操作などの一般的に使用されるjQueryメソッドのネイティブJavaScript同等物は、通常、jQueryの対応物よりも速く効率的に実行されます。たとえば、document.getElementsByClassNameまたはdocument.getElementByIdを使用すると、jqueryの$()ラッパーを使用するよりもはるかに高速になる場(chǎng)合があります。
  • HTML5は、フォーム検証のために追加のJavaScriptまたはjQueryコードを追加せずに、さまざまな一般的な入力タイプを組み込みサポートします。これらの新しいタイプをサポートしていない古いブラウザは、標(biāo)準(zhǔn)のテキスト入力フィールドに復(fù)元され、サーバー側(cè)の検証が必要です。
私の最近の「あなたは本當(dāng)にjQueryが必要ですか?記事、議論は続きますが、要するに、jQueryを使用する理由は2つあります。1。IE6/7/8をサポートする必要があります(jquery 2.0に移行できないことを忘れない)、または2。開発以上の費(fèi)用アプリケーションは、jQueryのようなライブラリを書くのに時(shí)間がかかります。

他のすべての狀況では実用的であることをお願(yuàn)いします。 jQueryは270kbのユニバーサルライブラリです。特定のモジュールを省略したとしても、それがコードの大きな塊であっても、それが提供するすべての機(jī)能を必要とする可能性は低いです。 CDNから30kbの削除バージョンをロードできますが、ブラウザは他のアクションを?qū)g行する前に、各ページの処理を停止し、コードを解析する必要があります。これは、一般的に使用されるjQueryメソッドにネイティブのJavaScriptに相當(dāng)するものを紹介する一連の記事の最初のものです。これらのいくつかを短く、同様のエイリアス機(jī)能で包みたいかもしれませんが、確かに獨(dú)自のjQueryのようなライブラリを作成する必要はありません。

dom selector

jQueryは、CSSセレクターの構(gòu)文を使用してDOMノードの選択を許可します。

ネイティブ同等物:
// 在 ID 為“first”的文章中查找所有具有類“summary”的段落
var n = $("article#first p.summary");

var n = document.querySelectorAll("article#first p.summary");
は、すべての最新のブラウザーとIE8に実裝されています(ただし、これはCSS2.1セレクターのみをサポートしています)。 jQueryは、より高度なセレクターに追加のサポートを提供しますが、ほとんどの場(chǎng)合、

ラッパー內(nèi)で実行されます。ネイティブJavaScriptは4つの選択肢も提供しています。これは、それらを使用できる場(chǎng)合よりもほぼ確実に高速です。

  1. document.querySelector(selector) - 最初の一致するノードのみを取得します
  2. document.getElementById(idname) - そのID名で単一のノードを取得
  3. document.getElementsByTagName(tagname) - 要素に一致するノードを取得します(H1、P、Strongなど)。
  4. document.getElementsByClassName(class) - 特定のクラス名を持つノードを取得

getElementsByTagNameおよびgetElementsByClassNameメソッドを単一のノードに適用して、結(jié)果を子孫のみに制限することもできます。たとえば

// 在 ID 為“first”的文章中查找所有具有類“summary”的段落
var n = $("article#first p.summary");
いくつかのテストをしましょう。私は「あなたは本當(dāng)にjqueryが必要ですか?」から得るためにいくつかの小さなスクリプトを書きました。 comment記事ですべてのコメントノードを10,000回検索します。結(jié)果:

厳格なラボ條件を主張することも、実際の使用法を反映していませんが、この場(chǎng)合、ネイティブのJavaScriptは60倍高速です。また、ID、タグ、またはクラスでノードを取得することは通常querySelectorAllよりも優(yōu)れていると述べています。

dom operation

jQueryは、次のようなDOMにさらに追加するいくつかの方法を提供します。

表面の下で、jQueryはネイティブ
// 在 ID 為“first”的文章中查找所有具有類“summary”的段落
var n = $("article#first p.summary");
メソッドを使用します。

innerHTMLDom Buildテクノロジーを使用することもできます。これらはより安全ですが、

var n = document.querySelectorAll("article#first p.summary");
よりも速くはめったにありません

innerHTMLjqueryですべての子ノードを削除することもできます:

var n = document.getElementById("first");
var p = n.getElementsByTagName("p");

$("#container").append("<p>more content</p>");
を使用するネイティブ等価物

innerHTMLまたは小さな関數(shù):

document.getElementById("container").innerHTML += "<p>more content</p>";

最後に、jqueryのDOMから要素全體を削除することができます:

var p = document.createElement("p");
p.appendChild(document.createTextNode("more content"));
document.getElementById("container").appendChild(p);

またはネイティブJavaScript:

$("#container").empty();

スケーラブルベクトルグラフィックス(SVG)
document.getElementById("container").innerHTML = null;

現(xiàn)在のドキュメントを処理するためにコアJQueryライブラリが開発されました。 SVGにはdomがありますが、jqueryはこれらのオブジェクトに直接操作を提供しません。通常、

などのメソッドが必要です。動(dòng)作し、いくつかのプラグインがありますが、獨(dú)自のコードを作成したり、rapha?lやsvg.jsなどの専用のSVGライブラリを使用する方が効率的です。

createElementNSgetAttributeNShtml5 form

最も基本的なWebアプリケーションでさえ、1つまたは2つのフォームがあります。サーバー側(cè)のユーザーデータを常に確認(rèn)する必要がありますが、理想的には、フォームを送信する前にエラーをキャッチできるように、クライアントの検証で補(bǔ)足します。クライアントの検証は簡(jiǎn)単です:1。フォームが送信されたときに関數(shù)を?qū)g行します。 2.問題が発生した場(chǎng)合は、送信を停止し、エラーを表示します。

jqueryを使用できます。ネイティブJavaScriptを使用できます。どちらを選ぶべきですか?

どちらも

を選択しません。 HTML5は、通常の表現(xiàn)に基づいて、電子メール、電話、URL、數(shù)字、時(shí)刻、日付、色、カスタムフィールドなど、一般的に使用されるさまざまな入力タイプをサポートしています。たとえば、ユーザーに電子メールアドレスを入力するように強(qiáng)制する場(chǎng)合は、以下を使用してください。

より複雑な機(jī)能(2つ以上のフィールドを比較したり、カスタムエラーメッセージの表示など)が必要な場(chǎng)合を除き、追加のJavaScriptまたはJQueryコードは必要ありません。古いブラウザ(IE9以下を含む)は新しいタイプを理解しておらず、標(biāo)準(zhǔn)のテキスト入力フィールドに復(fù)元されます。これらのユーザーは、サーバー側(cè)の検証に戻りますが、これは素晴らしい體験ではありませんが、シムを適用したり、これらの人々が光を見たりアップグレードしたりすることを願(yuàn)っています。私の次の投稿では、ネイティブCSSクラスの操作とアニメーションを見ていきます。 JQueryとネイティブJavaScript

var c = document.getElementById("container");
while (c.lastChild) c.removeChild(c.lastChild);
についての

faqs

(この部分の內(nèi)容が畫像と記事の主題に弱く関連しており、記事が長(zhǎng)くなっているため、FAQパーツはここで省略されています。

以上がjQueryメソッドのネイティブJavaScript同等物:DOMとフォームの詳細(xì)內(nèi)容です。詳細(xì)については、PHP 中國(guó)語 Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負(fù)いません。盜作または侵害の疑いのあるコンテンツを見つけた場(chǎng)合は、admin@php.cn までご連絡(luò)ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫像を無料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード寫真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡(jiǎn)単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中國(guó)語版

SublimeText3 中國(guó)語版

中國(guó)語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強(qiáng)力な PHP 統(tǒng)合開発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

node.jsでHTTPリクエストを作成する方法は? node.jsでHTTPリクエストを作成する方法は? Jul 13, 2025 am 02:18 AM

node.jsでHTTPリクエストを開始するには、組み込みモジュール、axios、およびnode-fetchを使用する3つの一般的な方法があります。 1.依存関係のない內(nèi)蔵http/httpsモジュールを使用します。これは基本的なシナリオに適していますが、https.get()を使用してデータを取得したり、.write()を介してPOSTリクエストを送信するなど、データステッチとエラーモニタリングの手動(dòng)処理が必要です。 2.Axiosは、約束に基づいたサードパーティライブラリです。簡(jiǎn)潔な構(gòu)文と強(qiáng)力な機(jī)能を備えており、非同期/待ち聲、自動(dòng)JSON変換、インターセプターなどをサポートします。非同期リクエスト操作を簡(jiǎn)素化することをお?jiǎng)幛幛筏蓼埂?3.Node-Fetchは、約束と単純な構(gòu)文に基づいて、ブラウザフェッチに似たスタイルを提供します

JavaScriptデータ型:プリミティブ対參照 JavaScriptデータ型:プリミティブ対參照 Jul 13, 2025 am 02:43 AM

JavaScriptデータ型は、プリミティブタイプと參照タイプに分割されます。プリミティブタイプには、文字列、數(shù)字、ブール、ヌル、未定義、シンボルが含まれます。値は不変であり、コピーは値を割り當(dāng)てるときにコピーされるため、互いに影響を與えません。オブジェクト、配列、関數(shù)などの參照タイプはメモリアドレスを保存し、同じオブジェクトを指す変數(shù)は互いに影響します。 TypeofとInstanceOFを使用してタイプを決定できますが、TypeOfNullの歴史的な問題に注意してください。これらの2種類の違いを理解することは、より安定した信頼性の高いコードを書くのに役立ちます。

JavaScript Timeオブジェクト、誰かがEACTEXE、Google Chromeなどのより高速なWebサイトを構(gòu)築します。 JavaScript Timeオブジェクト、誰かがEACTEXE、Google Chromeなどのより高速なWebサイトを構(gòu)築します。 Jul 08, 2025 pm 02:27 PM

こんにちは、JavaScript開発者!今週のJavaScriptニュースへようこそ!今週は、DenoとのOracleの商標(biāo)紛爭(zhēng)、新しいJavaScript Timeオブジェクトがブラウザ、Google Chromeアップデート、およびいくつかの強(qiáng)力な開発ツールによってサポートされています。始めましょう! 「JavaScript」の商標(biāo)を登録しようとするDeno Oracleの試みとのOracleの商標(biāo)紛爭(zhēng)は、論爭(zhēng)を引き起こしました。 Node.jsとDenoの作成者であるRyan Dahlは、商標(biāo)をキャンセルするために請(qǐng)願(yuàn)書を提出しました。

ハンドリングの約束:javascriptのチェーン、エラー処理、および約束の組み合わせ ハンドリングの約束:javascriptのチェーン、エラー処理、および約束の組み合わせ Jul 08, 2025 am 02:40 AM

約束は、JavaScriptで非同期操作を処理するためのコアメカニズムです。チェーンコール、エラー処理、コンビナーの理解は、アプリケーションをマスターするための鍵です。 1.チェーンコールは、.then()を通じて新しい約束を返し、非同期プロセスの連結(jié)を?qū)g現(xiàn)します。それぞれ.then()は以前の結(jié)果を受け取り、値または約束を返すことができます。 2。エラー処理は、.catch()を使用して例外をキャッチしてサイレント障害を回避し、キャッチのデフォルト値を返すためにプロセスを継続する必要があります。 3。promise.all()などの組み合わせ(すべての成功後にのみ成功しました)、promise.race()(最初の完了が返されます)、promise.allsettled()(すべての完了を待っています)

キャッシュAPIとは何ですか?また、サービスワーカーでどのように使用されますか? キャッシュAPIとは何ですか?また、サービスワーカーでどのように使用されますか? Jul 08, 2025 am 02:43 AM

Cacheapiは、ブラウザからネットワークリクエストをキャッシュするツールです。これは、ウェブサイトのパフォーマンスとオフラインエクスペリエンスを改善するために、サービスワーカーと併用することがよくあります。 1.開発者は、スクリプト、スタイルシート、寫真などのリソースを手動(dòng)で保存できるようにします。 2。要求に応じてキャッシュ応答と一致させることができます。 3.特定のキャッシュの削除またはキャッシュ全體のクリアをサポートします。 4.フェッチイベントを聞いているサービスワーカーを介して、キャッシュの優(yōu)先順位またはネットワークの優(yōu)先戦略を?qū)g裝できます。 5.オフラインサポート、繰り返しのアクセス速度の高速化、主要なリソースのプリロード、バックグラウンドアップデートコンテンツによく使用されます。 6.それを使用する場(chǎng)合、キャッシュバージョンの制御、ストレージ制限、およびHTTPキャッシングメカニズムとの違いに注意する必要があります。

JSラウンドアップ:JavaScriptイベントループに深く潛り込む JSラウンドアップ:JavaScriptイベントループに深く潛り込む Jul 08, 2025 am 02:24 AM

JavaScriptのイベントループは、コールスタック、WebAPIS、およびタスクキューを調(diào)整することにより、非同期操作を管理します。 1.コールスタックは同期コードを?qū)g行し、非同期タスクに遭遇すると、処理のためにWebAPIに引き渡されます。 2。WebAPIがバックグラウンドでタスクを完了した後、コールバックを?qū)潖辘工毳濠`(マクロタスクまたはマイクロタスク)に入れます。 3.イベントループは、コールスタックが空であるかどうかをチェックします??栅螆?chǎng)合、コールバックはキューから取り出され、実行のためにコールスタックに押し込まれます。 4.マイクロタスク(Promise.thenなど)は、マクロタスク(SettimeOutなど)より優(yōu)先されます。 5.イベントループを理解するには、メインスレッドのブロックを避け、コード実行順序を最適化するのに役立ちます。

JavaScript DOMイベントでのイベントの泡立ちとキャプチャの理解 JavaScript DOMイベントでのイベントの泡立ちとキャプチャの理解 Jul 08, 2025 am 02:36 AM

イベントの泡は、ターゲット要素から祖先ノードに外側(cè)に伝播し、イベントキャプチャは外側(cè)の層からターゲット要素に內(nèi)側(cè)に伝播します。 1。イベントバブル:子要素をクリックした後、イベントは親要素のリスナーを上向きにトリガーします。たとえば、ボタンをクリックした後、最初に保育を出してから、親クリックしました。 2。イベントキャプチャ:3番目のパラメーターをtrueに設(shè)定して、リスナーが[親子要素のキャプチャリスナー]をクリックする前に[親要素のキャプチャリスナーをトリガーするなど、キャプチャステージで実行されるようにします。 3.実用的な用途には、子どもの要素イベントの統(tǒng)一された管理、傍受前処理、パフォーマンスの最適化が含まれます。 4. DOMイベントストリームは、キャプチャ、ターゲット、バブルの3つの段階に分割され、デフォルトのリスナーはバブルステージで実行されます。

マップとフィルターを超えて高次関數(shù)のJSラウンドアップ マップとフィルターを超えて高次関數(shù)のJSラウンドアップ Jul 10, 2025 am 11:41 AM

JavaScriptアレイには、Map and Filterに加えて、他の強(qiáng)力で使用されていない方法があります。 1.還元は、合計(jì)するだけでなく、カウント、グループ、フラットンアレイ、新しい構(gòu)造を構(gòu)築することもできます。 2。FindおよびFindIndexは、個(gè)々の要素またはインデックスを見つけるために使用されます。 3.一部とすべてが條件が存在するか、すべての出會(huì)いかを判斷するために使用されます。 4.ソートはソートできますが、元の配列を変更します。 5.副作用を避けるために、それを使用するときにアレイをコピーすることに注意してください。これらの方法により、コードがより簡(jiǎn)潔で効率的になります。

See all articles