検索
ホームページウェブフロントエンドjsチュートリアルJavaScript変数スコープ解析(詳細説明)
JavaScript変数スコープ解析(詳細説明)Sep 13, 2018 pm 05:50 PM
javascript変数スコープ

この章では、JavaScript 変数のスコープ分析 (詳細な説明) を紹介します。これにより、JavaScript スコープに関するちょっとした知識を学ぶことができます。困っている友人は参考にしていただければ幸いです。

JavaScript スコープとは何ですか?

JavaScript では、スコープはアクセス可能な変数、オブジェクト、関数のコレクションです。

スコープは関数内で変更できます。

JavaScript ローカル スコープ

変数は関数内で宣言され、ローカル変数 (ローカル スコープ)です。

ローカル変数:関数内でのみアクセスできます。

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
    <button onclick="myFunction(1,2)">试一试</button>
    <p id="demo"></p>
</body>
<script type="text/javascript">
    function name() {
        //在此处声明一个变量
        var a = 10;
        //函数内可以调用 a
    }
    //此处(函数外)不能调用变量 a  
    //因为局部变量只作用于函数内,所以不同的函数可以使用相同名称的变量名  
    //局部变量在函数开始执行时创建,函数执行完毕后,变量会自动销毁
</script>
</html>

JavaScript グローバル変数

関数の外部で定義された変数はグローバル変数です。

グローバル変数にはグローバル スコープがあり、Web ページ内のすべてのスクリプトと関数で使用できます。

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
    <button onclick="myFunction(1,2)">试一试</button>
    <p id="demo"></p>
</body>
<script type="text/javascript">
    /* 在此处声明一个全局变量 */
    var a = 10;
    function name() {
        //函数内可以调用 a
    }
    //此处也能调用变量 a
</script>
</html>

変数が関数内で宣言されていない (var キーワードを使用して宣言されていない) 場合、変更量はグローバル変数になります。

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
    <button onclick="myFunction(1,2)">试一试</button>
    <p id="demo"></p>
</body>
<script type="text/javascript">
    
    function name() {
        /* 在此处声明一个变量 */
          a = 10;
     /* a没有使用var关键字声明,则默认为全局变量 */

    }
    
</script>
</html>

JavaScript 変数のライフ サイクル

変数のライフ サイクルは、宣言時に初期化されます。ローカル変数は、関数の実行が完了すると破棄されます。グローバル変数は、ページが閉じられると破棄されます。

関数パラメータ

関数パラメータは関数内でのみ機能し、ローカル変数です。

HTML のグローバル変数

HTML では、グローバル変数はウィンドウ オブジェクトであり、すべてのデータ変数はウィンドウ オブジェクトに属します。

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
    <button onclick="myFunction(1,2)">试一试</button>
    <p id="demo"></p>
</body>
<script type="text/javascript">
    function name() {
         a = 10;
    }
    //此处可使用window.a调用变量 a
</script>
</html>

グローバル変数または関数は、ウィンドウ オブジェクトの変数または関数をオーバーライドできます。ローカル変数にはウィンドウ オブジェクトが含まれており、グローバル変数や関数をオーバーライドできます。

let キーワードと const キーワードは es6 で提供されます

let の宣言方法は var の宣言方法と同じです。var の代わりに let を使用して変数を宣言すると、現在の変数を次のように制限できます。コードブロック。

const を使用して定数を宣言すると、その値は一度設定されると変更できません。

以上がJavaScript変数スコープ解析(詳細説明)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
es6数组怎么去掉重复并且重新排序es6数组怎么去掉重复并且重新排序May 05, 2022 pm 07:08 PM

去掉重复并排序的方法:1、使用“Array.from(new Set(arr))”或者“[…new Set(arr)]”语句,去掉数组中的重复元素,返回去重后的新数组;2、利用sort()对去重数组进行排序,语法“去重数组.sort()”。

PHP 函数的变量作用域是如何确定的?PHP 函数的变量作用域是如何确定的?Apr 16, 2024 pm 04:51 PM

PHP中的变量作用域分为局部(函数内)、全局(程序内可访问)、类范围(类实例内可访问)。global关键字可将局部变量声明为全局变量,static关键字可将局部变量声明为静态变量,在函数调用间保留其值。

深入理解 Golang 函数生命周期与变量作用域深入理解 Golang 函数生命周期与变量作用域Apr 19, 2024 am 11:42 AM

在Go中,函数生命周期包括定义、加载、链接、初始化、调用和返回;变量作用域分为函数级和块级,函数内的变量在内部可见,而块内的变量仅在块内可见。

Go语言中的变量作用域与生命周期Go语言中的变量作用域与生命周期Jun 01, 2023 pm 12:31 PM

Go语言是一种开源的静态类型语言,它具有简洁、高效、可靠等特点,越来越受到开发者的喜爱。在Go语言中,变量是程序中最基本的数据存储形式,变量的作用域和生命周期对于程序的正确性和效率十分重要。变量的作用域指的是变量的可见性和可访问性,即在何处可以访问这个变量。在Go语言中,变量的作用域分为全局变量和局部变量。全局变量是定义在函数外部的变量,它可以被整个程序任何

JavaScript对象的构造函数和new操作符(实例详解)JavaScript对象的构造函数和new操作符(实例详解)May 10, 2022 pm 06:16 PM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于对象的构造函数和new操作符,构造函数是所有对象的成员方法中,最早被调用的那个,下面一起来看一下吧,希望对大家有帮助。

Golang函数如何定义变量作用域?Golang函数如何定义变量作用域?Apr 11, 2024 pm 12:27 PM

在Go中,函数作用域限制变量可见性,限定在变量声明所在的函数内:在函数内声明变量:varnametype=value作用域仅限于声明的代码块,其他函数或嵌套块无法访问这些变量

PHP 5.6变量作用域:如何使用static关键字定义静态变量PHP 5.6变量作用域:如何使用static关键字定义静态变量Jul 30, 2023 pm 11:02 PM

PHP5.6变量作用域:如何使用static关键字定义静态变量在PHP中,变量的作用域决定了变量的可见性和访问范围。静态变量是一种特殊类型的变量,它在函数调用之间保持其值不变。在PHP5.6及其以上版本中,可以使用static关键字在函数内部和类方法中定义静态变量。静态变量的特点是:静态变量的作用域仅限于声明它的函数或方法内部。静态变量在函数或方法调用之

JavaScript面向对象详细解析之属性描述符JavaScript面向对象详细解析之属性描述符May 27, 2022 pm 05:29 PM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于面向对象的相关问题,包括了属性描述符、数据描述符、存取描述符等等内容,下面一起来看一下,希望对大家有帮助。

See all articles

ホット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衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

SublimeText3 中国語版

SublimeText3 中国語版

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

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。