ブラウザは JavaScript をどのように解析しますか?この記事では、ブラウザの JavaScript 解析の原理について説明します。必要な方は参考にしていただければ幸いです。 [推奨ビデオ チュートリアル: JavaScript ビデオ チュートリアル]
ブラウザ解析 JavaScript の基本機能:
1. クロスプラットフォーム
2. 弱い型の JavaScript を定義する場合、データ型を定義する必要はありません。
var a = 10; //数字类型 var a = true //boolean类型
(強い型: 変数を定義する場合)。 、変数の型を定義する必要があります。たとえば、Java、C# では int a = 10 boolean a = true はデータ型を直接決定します)
3.一行ずつ
javascript 実行プロセス
#1. 文法検出
基本的な文法があるかどうかを確認します。中国語、キーワード エラーなど...
2. 字句解析 (コンパイル前)
3. 行ごとに実行します。字句解析コンパイル前プロセス (2 つの状況)
1. グローバル
(関数の実行を除く、スクリプト タグ内のコード)次のデモを例に挙げます:
console.log(a); console.log(b) var a = 100; console.log(a) var b = 200 var c = 300 function a(){ } function fun(){ }
GO = { //自带的属性都不写 }
変数宣言
、変数名は属性名、値は未定義です。GO = { a : undefined, b : undefined, c : undefined }
GO = { a : function a(){ }, b : undefined, c : undefined, fun : function fun(){ } }
a赋了一次值,值改变为100 GO = { a : 100, b : undefined, c : undefined, fun : function fun(){ } }
2
,ローカル (関数の実行時) このデモを例として取り上げます:
num = 100510)
GO = { num : undefined, fun : function }
GO = { num : 100, fun : function }
fun.AO = { }
例:
例 1:
fun.AO = { num : 5 }
以上がブラウザはどのようにして JavaScript を解析するのでしょうか?分析原理の紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。fun.AO = {
num : 5
}