摘要:注意使用操作符定義的變量將成為定義該變量的作用域中的局部變量,也就是說,在函數內部,用聲明的變量叫局部變量,那么這個變量在函數退出后就會被銷毀。局部變量報錯如果省略了操作符,就相當于定義了一個全局變量,在函數外部的任何地方都可以訪問到。
2.1 語法
2.1.1 區分大小寫
JavaScript中的一切(變量、函數名和操作符)都區分大小寫。比如變量名test和變量名Test代表的是兩個不同的變量。
2.1.2 標識符
標識符是指變量、函數、屬性的名字,或函數的參數。
標識符格式規則:
第一個字符必須是一個字母、下劃線(_)或一個美元符號($)
其他字符可以是字母、下劃線、美元符號或數字。
按照慣例,JavaScript標識符采用駝峰大小寫格式,也就是第一個字母小寫,剩下的每個有意義的單詞的首字母大寫。
myName
注意:不能把關鍵字、保留字、true、false和null用作標識符。
2.1.3 注釋
單行注釋:
// 單行注釋
多行注釋(/**/):
/* * 多行注釋,這一行星號非必需 */
2.1.4 嚴格模式
ECMAScript 5 引入了嚴格模式(strict mode)的概念。嚴格模式是為JavaScript定義了一種不同的解析與執行模型。
在嚴格模式下,ECMAScript 3中的一些不確定的行為將得到處理,而且對某些不安全的操作也會拋出錯誤。
可以在整個腳本中啟用嚴格模式,也可以在函數內的頂部啟用:
"use strict"; function doSomething(){ "use strict"; // 函數體 }
2.1.5 語句
ECMAScript中的語句以一個分號結尾;如果省略分號,則由解析器確定語句的結尾。
強烈建議在可用可不用分號的地方使用分號,因為加上分號,可以避免很多意想不到的錯誤,而且也可以放心的使用壓縮工具來壓縮JavaScript腳本。
2.2 關鍵字和保留字
ECMA-262描述了一組具有特定用途的關鍵字,這些關鍵字可用于控制語句的開始或結束,或者用于執行特定操作等,不能用作標識符。
break do instanceof typeof case else new var catch finally return void continue for switch while debugger function this with default if throw delete in try
ECMA-262還描述了一組不能用作標識符的保留字:
abstract enum int short boolean export interface static byte extends long super char final native synchronized class float package throws const goto private transient debugger implements protected volatile double import public
如果使用關鍵字作標識符,會導致“Identifier Expected”錯誤。
2.3 變量
ECMAScript的變量是松散類型的,所謂松散類型就是可以用來保存任何類型的數據。定義變量時要使用var操作符,后跟變量名。
var name;
注意:使用var操作符定義的變量將成為定義該變量的作用域中的局部變量,也就是說,在函數內部,用var聲明的變量叫局部變量,那么這個變量在函數退出后就會被銷毀。
function test(){ var name = "tg"; //局部變量 } test(); console.log(name); // 報錯
如果省略了var操作符,就相當于定義了一個全局變量,在函數外部的任何地方都可以訪問到。
function test(){ name = "tg"; //局部變量 } test(); console.log(name); // "tg"
不推薦省略var操作符。
還有一種隱式全局變量:
function test() { var a = b = 0; } test(); console.log(b); // 0 console.log(a); // ReferenceError: a is not defined
在上面的代碼中,由于從右至左的操作符優先級,所以表達式“b=0”是先執行的,而此時b未經過聲明,所以它會成為全局變量。
注意:
使用var創建的全局變量不能刪除。
不適應var創建的隱含全局變量可以使用delete刪除(因為它并不是真正的變量,而是全局對象window的屬性)。
function test() { var a = b = 0; delete a; delete b; console.log(a); // 0 console.log(b); // ReferenceError: b is not defined } test();
2.3.1 變量提升
變量提升是指所有變量的聲明語句,都會被提升到代碼的頭部。
在函數內也一樣,函數中的所有變量聲明會在函數執行時被“提升”至函數體頂端。
看個例子:
console.log(a); // undefined var a = 1; function test(){ console.log(a); // undefined var a = 2; } test();
結果是不是有點出乎你的意料。
其實JavaScript的執行環境分為聲明階段和執行階段,因此對于上面的代碼,JavaScript會這樣解釋代碼:
var a; console.log(a); // undefined a = 1; function test(){ var a; console.log(a); // undefined a = 2; } test();
2.3.2 復制變量值
如果從一個變量向另一個變量復制基本類型的值,會在變量對象上創建一個新值,然后把該值復制到為新變量分配的位置上。
var num1 = 5; var num2 = num1; num2 += 5; console.log(num1); //5 console.log(num2); // 10
從上面例子的結果,我們知道num1中的5和num2中的5是完全獨立的,num2中的5只是num1中的5的一個副本。
當從一個變量向另一個變量復制引用類型的值時,同樣會將存儲在變量對象中的值復制一份放到為新變量分配的空間中。不同的是,這個值的副本實際上是一個指針,而這個指針指向存儲在堆中的一個對象。復制操作結束后,兩個變量實際上將引用同一個對象。因此,改變其中一個變量,就會影響到另一個變量。
var obj1 = new Object(); var obj2 = obj1; obj2.name = "tg"; console.log(obj1.name); // "tg"
在上面的例子中,我們將obj1賦給了obj2,兩者就指向了同一個對象,然后給obj2添加了一個屬性name,接著訪問obj1中的name,發現值和obj2中的name是一樣,因為這兩個變量引用的都是同一個對象。
2.4 空格、換行符
JavaScript會忽略程序中標識符之間的空格。在大多數情況下忽略換行符。
我們可以使用空格和換行來提高代碼的可讀性。
除了可以識別普通的空格符(u0020),JavaScript還可以識別如下表示空格的字符:
水平制表符(u0009)
垂直制表符(u000B)
換頁符(u000C)
不中斷空表(u00A0)
字節序標記(uFEFF)
JavaScript會將如下字符識別為行結束符:
換行符(u000A)
回車符(u000D)
行分隔符(u2028)
段分隔符(u2029)
回車符加換行符在一起被解析為一個單行結束符。
2.5 Unicode轉義序列
JavaScript定義了一種特殊序列,使用6個ASCII字符來代表任意16位Unicode內碼。這些Unicode轉義序列碼均以u為前綴,其后跟隨4個十六進制(使用數字以及大寫或小寫的字母A~Fa~f表示)。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/81981.html
摘要:在這篇文章中,我將會從個方面概述和在語法上的差異。獲取標簽的屬性與上述類似,我們有不同的語法來獲取標簽的屬性。這個示例代碼是相當基礎的,一般用作許多復雜事件處理的一部分,這里僅用來描述差異。語法語法透明處理這不是的語法問題,是通過設置的。 原文:http://www.impressivewebs.com/7-javascript-differences-between-firefox-...
摘要:基礎語法區分大小寫是一種區分大小寫的語法,意味著的關鍵字變量名函數名以及其他一切的字符表示都要使用一致的大小寫形式。化物語化物語空格和換行會忽略代碼中出現的空格換行制表符。如果不用花括號獨立獨立編寫一個語句,語法并不報錯,但不推薦。 JavaScript基礎語法 區分大小寫 JavaScript是一種區分大小寫的語法,意味著JavaScript的關鍵字、變量名、函數名以及其他一切的字符...
JS(JavaScript) 一?;A語法; 1.語法; 區分大小寫; 他的標識符必須以大小寫區分使用實為形式,不同的大小寫代表不一樣的意思 var aixinjueluo = 愛新覺羅; console.log(aixinjueluo); var Aixinjueluo = Aixinjueluo; console.log(Aixinjueluo); var AIXINJUELUO = AIXI...
摘要:第十六天筆記基礎語法區分大小寫是一種區分大小寫的語言的關鍵字變量名函數名以及任何其他的標識符必須適應一致的大小寫形勢臥龍前端空格和換行并不是的語法內容可有可無建議使用將代碼書寫的更加整潔美觀更有可讀性可選的分號分號可選項語法并不是強制要 第十六天筆記 JavaScript 基礎語法 區分大小寫 JavaScript是一種區分大小寫的語言 JavaScript的關鍵字 變量名 函...
摘要:上一篇學習下一代語法一,我們學習了關于塊作用域變量或常量聲明和語法新的字符串拼接語法模版字面量數組元素或對象元素的解構賦值和對象字面量簡寫的相關知識。這便是擴展運算符的用途之一。 本文同步 帶你入門 JavaScript ES6 (二),轉載請注明出處。 上一篇學習下一代 JavaScript 語法: ES6 (一),我們學習了關于塊作用域變量或常量聲明 let 和 const 語法、...
閱讀 2779·2023-04-26 01:47
閱讀 3591·2023-04-25 23:45
閱讀 2461·2021-10-13 09:39
閱讀 606·2021-10-09 09:44
閱讀 1789·2021-09-22 15:59
閱讀 2761·2021-09-13 10:33
閱讀 1706·2021-09-03 10:30
閱讀 656·2019-08-30 15:53