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