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

ホームページ ウェブフロントエンド jsチュートリアル javascript変數(shù)スコープと巻き上げを分類します

javascript変數(shù)スコープと巻き上げを分類します

Feb 10, 2025 am 09:35 AM

JavaScript変數(shù)スコープと巻き上げの理解:包括的なガイド

Demystifying JavaScript Variable Scope and Hoisting

プログラミングの礎(chǔ)石である可変スコープは、プログラム內(nèi)の変數(shù)のアクセシビリティを決定します。 このガイドは、変動する宣言方法、グローバル対ローカルスコープ、およびしばしば驚くべき巻き上げの概念をカバーするJavaScriptのスコーピングメカニズムを掘り下げます。これらの概念を習(xí)得することは、堅牢でエラーのないJavaScriptアプリケーションを構(gòu)築するために重要です。

重要な概念:

JavaScriptは、グローバルとローカルの2つの主要な範(fàn)囲タイプを採用しています。ローカルスコープは、さらに機能スコープ(
    の場合)およびブロックスコープ(
  • およびvar)に細分化されます。 letconst宣言は関數(shù)の上部に巻き上げられ、
  • はブロックの上部に巻き上げられますが、「時間的なデッドゾーン」を作成します。 プログラム全體でアクセス可能なグローバル変數(shù)は、潛在的な競合と偶発的な上書きのために一般的に落膽します。 var関數(shù)宣言は完全に巻かれており、標(biāo)準(zhǔn)の巻き上げルールに付著する関數(shù)式とは異なり、定義の前に呼び出しを有効にします。 letJavaScriptのスコーピングおよび巻き上げルールの適切な理解と適用は、一般的な変數(shù)関連のバグを防ぎ、コードの信頼性を高めます。 const
  • 可変スコープ詳細:
  • JavaScriptの変數(shù)の範(fàn)囲は、宣言の場所によって決定され、プログラム內(nèi)のアクセシビリティを定義します。 変數(shù)宣言には3つの方法が存在します:レガシー
  • キーワードと最新の
  • および
キーワード。 一方、

は唯一のオプションでしたが、ES6以前、、はより厳格なルールを提供し、コードの信頼性を向上させます。

JavaScriptには、グローバルとローカルの2つの主要なスコープがあります。ローカルスコープは、さらに関數(shù)スコープ(

の場合)およびブロックスコープ(varおよびletの場合)に分岐します。 関數(shù)スコープは、ブロックスコープの特殊な形式です constvarグローバルスコープ:letconst

スクリプト內(nèi)の最も外側(cè)のスコープは、グローバルスコープです。ここで宣言された変數(shù)はグローバルになり、プログラムのどこからでもアクセス可能になります:

var let便利ですが、潛在的な競合と上書きにより、一般的にグローバル変數(shù)は落膽します。 const

ローカルスコープ:

ブロック內(nèi)で宣言された変數(shù)(例えば、、

、関數(shù))は、そのブロックのローカルです。 関數(shù)は、

、

、および
// Global Scope
const name = "Monique";

function sayHi() {
  console.log(`Hi ${name}`);
}

sayHi(); // Hi Monique
で宣言された変數(shù)の範(fàn)囲を定義します。 コードブロックは、

および

のスコープのみを定義します。

は関數(shù)スコープに制限されています

letおよびconstブロックスコープを?qū)毪?、各ブロックの新しいローカルスコープを作成します。スタンドアロンブロックは、スコープも定義します:

// Global Scope
const name = "Monique";

function sayHi() {
  console.log(`Hi ${name}`);
}

sayHi(); // Hi Monique

ネストされたスコープが可能であり、內(nèi)側(cè)のスコープは外側(cè)のスコープからの変數(shù)にアクセスしますが、その逆ではありません。

スコープの視覚的メタファー:

世界を想像してみてください。國には國境(スコープ)があり、國內(nèi)の都市には獨自のスコープなどがあります。 グローバルな範(fàn)囲は、すべてを網(wǎng)羅する世界の海のようなものです。 この類推は、スコープの仕組みを示しています。変數(shù)の検索は、最も內(nèi)側(cè)のスコープで始まり、発見されるかエラーが発生するまで外側(cè)に進みます。このルックアップは、語彙(靜的)スコーピングと呼ばれます

巻き上げ:

JavaScriptの「ホイスト」メカニズムは、コンピレーション中に変數(shù)と関數(shù)宣言をスコープの上部に移動します。 ただし、宣言のみが巻かれています。割り當(dāng)てはそのまま殘っています。 これを考えてみてください:

出力は
{
  // standalone block scope
}

undefinedが宣言されているが、まだ割り當(dāng)てられていないためです。 エンジンはそれを次のように解釈します:state

console.log(state); // undefined
var state = "ready";

およびlet変數(shù)も巻き上げられますが、初期化されていないため、宣言の前に「時間的デッドゾーン」(TDZ)が生じます。 TDZ內(nèi)でそれらにアクセスすると、a const。ReferenceError

関數(shù)と巻き上げ:

関數(shù)宣言は完全に巻かれており、定義の前に通話を許可します。

ただし、関數(shù)式は、標(biāo)準(zhǔn)の巻き上げルールに従います(宣言が掲げられ、割り當(dāng)てが殘ります)。 クラスは、

変數(shù)と同様に動作します。
var state; // hoisted
console.log(state);
state = "ready";

let主要な違いとベストプラクティス:

:function-scoped。
  • varおよび
  • :block-scoped。
  • letすべての宣言は巻かれています。const
  • 関數(shù)は変數(shù)の前に巻き上げられます。
  • 関數(shù)宣言は、変動宣言よりも優(yōu)先されますが、割り當(dāng)てではありません。
  • よくある質(zhì)問:
  • 可変スコープとは?変數(shù)がアクセス可能な領(lǐng)域。
  • グローバルvs.ローカルスコープ?グローバル:どこでもアクセスできます。ローカル:ブロックまたは関數(shù)に制限されています。
  • ブロックスコープ?ブロックで定義されたローカルスコープ(およびletを使用)。 const
  • ホイストはどのように機能しますか?
  • 宣言は範(fàn)囲の最上部に移動されます。
  • 宣言と巻き上げの初期化?
  • 宣言は巻き上げられており、初期化は殘っています。
  • and
  • ? ??hoistedで巻き上げられますが、初期化されていません。 TDZが適用されます let JavaScriptのスコーピングと巻き上げを理解することにより、開発者はよりクリーナー、より予測可能で、エラーが発生しやすいコードを書き込むことができます。 コードの組織と保守性を向上させるために、ブロックスコープ(constおよび)を活用することを忘れないでください。

以上がjavascript変數(shù)スコープと巻き上げを分類しますの詳細內(nèi)容です。詳細については、PHP 中國語 Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負いません。盜作または侵害の疑いのあるコンテンツを見つけた場合は、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 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中國語版

SublimeText3 中國語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

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

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Java vs. JavaScript:混亂を解消します Java vs. JavaScript:混亂を解消します Jun 20, 2025 am 12:27 AM

JavaとJavaScriptは異なるプログラミング言語であり、それぞれ異なるアプリケーションシナリオに適しています。 Javaは大規(guī)模なエンタープライズおよびモバイルアプリケーション開発に使用されますが、JavaScriptは主にWebページ開発に使用されます。

JavaScriptコメント:短い説明 JavaScriptコメント:短い説明 Jun 19, 2025 am 12:40 AM

JavaScriptcommentsEareEssentialential-formaining、およびGuidingCodeexecution.1)single-linecommentseared forquickexplanations.2)多LinecommentsexplaincomplexlogiCorprovidededocumentation.3)clarifyspartsofcode.bestpractic

JSで日付と時間を操作する方法は? JSで日付と時間を操作する方法は? Jul 01, 2025 am 01:27 AM

JavaScriptで日付と時間を処理する場合は、次の點に注意する必要があります。1。日付オブジェクトを作成するには多くの方法があります。 ISO形式の文字列を使用して、互換性を確保することをお勧めします。 2。時間情報を取得および設(shè)定して、メソッドを設(shè)定でき、月は0から始まることに注意してください。 3.手動でのフォーマット日付には文字列が必要であり、サードパーティライブラリも使用できます。 4.ルクソンなどのタイムゾーンをサポートするライブラリを使用することをお勧めします。これらの重要なポイントを習(xí)得すると、一般的な間違いを効果的に回避できます。

なぜの下部にタグを配置する必要があるのですか? なぜの下部にタグを配置する必要があるのですか? Jul 02, 2025 am 01:22 AM

PLACSTHETTHETTHE BOTTOMOFABLOGPOSTORWEBPAGESERVESPAGESPORCICALPURPOSESESFORSEO、userexperience、andDesign.1.IthelpswithiobyAllowingseNStoAccessKeysword-relevanttagwithtagwithtagwithtagwithemaincontent.2.iTimrovesexperiencebyepingepintepepinedeeping

JavaScript vs. Java:開発者向けの包括的な比較 JavaScript vs. Java:開発者向けの包括的な比較 Jun 20, 2025 am 12:21 AM

javascriptispreferredforwebdevelopment、whilejavaisbetterforlge-scalebackendsystemsandroidapps.1)javascriptexcelsininintingtivewebexperiences withitsdynAmicnature anddommanipulation.2)javaofferstruntypyping-dobject-reientedpeatures

DOMでのイベントの泡立ちとキャプチャとは何ですか? DOMでのイベントの泡立ちとキャプチャとは何ですか? Jul 02, 2025 am 01:19 AM

イベントキャプチャとバブルは、DOMのイベント伝播の2つの段階です。キャプチャは最上層からターゲット要素までであり、バブルはターゲット要素から上層までです。 1.イベントキャプチャは、AddEventListenerのUseCaptureパラメーターをTrueに設(shè)定することにより実裝されます。 2。イベントバブルはデフォルトの動作であり、UseCaptureはfalseに設(shè)定されているか、省略されます。 3。イベントの伝播を使用して、イベントの伝播を防ぐことができます。 4.イベントバブルは、動的なコンテンツ処理効率を改善するためにイベント委任をサポートします。 5.キャプチャを使用して、ロギングやエラー処理など、事前にイベントを傍受できます。これらの2つのフェーズを理解することは、タイミングとJavaScriptがユーザー操作にどのように反応するかを正確に制御するのに役立ちます。

JavaScript:効率的なコーディングのためのデータ型の調(diào)査 JavaScript:効率的なコーディングのためのデータ型の調(diào)査 Jun 20, 2025 am 12:46 AM

javascripthassevenfundamentaldatypes:number、string、boolean、undefined、null、object、andsymbol.1)numberseadouble-precisionformat、有用であるため、有用性の高いものであるため、but-for-loating-pointarithmetic.2)ストリングリムムット、使用率が有用であること

JavaScriptアプリケーションのペイロードサイズをどのように削減できますか? JavaScriptアプリケーションのペイロードサイズをどのように削減できますか? Jun 26, 2025 am 12:54 AM

JavaScriptアプリケーションがゆっくりとロードされ、パフォーマンスが低い場合、問題はペイロードが大きすぎることです。ソリューションには、次のものが含まれます。1。コード分割(コードスプリッティング)を使用し、React.lazy()またはビルドツールを介して大きなバンドルを複數(shù)の小さなファイルに分割し、最初のダウンロードを減らすために必要に応じてロードします。 2。未使用のコード(Treeshaking)を削除し、ES6モジュールメカニズムを使用して「デッドコード」をクリアして、導(dǎo)入されたライブラリがこの機能をサポートしていることを確認します。 3.リソースファイルを圧縮してマージし、GZIP/BrotliとTerserがJSを圧縮できるようにし、ファイルを合理的にマージし、靜的リソースを最適化します。 4.頑丈な依存関係を交換し、day.jsやフェッチなどの軽量ライブラリを選択します

See all articles