[1]變數特性 [2]變數命名 [3]變數聲明 [4]變數賦值 [5]標識符命名 [6]標識符解析
目錄
[1]變數 變數特性 變數命名 變數聲明 變數賦值 [2]標識符 標識符命名 標識符解析變數
從字面上看,變數是可變的量;從編程角度講,變數是用於存儲數據的容器
變數特性
javascript中的變數是鬆散類型的,可以保存任何類型的數據。由於不存在定義某個變數必須要保存何種數據類型值的規則,變數的值及其數據類型可以在腳本的生命周期內改變
變數命名
變數可以任意取名,但必須遵循命名規則:
[1]第一個字元必須是字母、下劃線或美元符號。其他字元可以是字母、下劃線、美元符號或數字
//錯誤示範 6num //開頭不能用數字 %sum //開頭不能用除(_ $)外特殊符號,如(% + /等) sum+num //開頭中間不能使用除(_ $)外特殊符號,如(% + /等)
[2]字元中的字母可以包括拓展的ASCII或Unicode字母字元,也可以使用中文
[3]不能使用關鍵字、保留字、true、false和null
[4]變數對大小寫敏感
[5]標識符應採用小駝峰格式,第一位應該是數據的類型,常見的標識如下:
數組 a Array aItems
布爾值 b Boolean bIsComplete
浮點數 f Float fPrice
函數 fn Function fnHandler
整數 i Integer iItemCount
對象 o Object oDIv1
正則表達式 re RegExp reEmailCheck
字元串 s String sUserName
變數 v Variant vAnything
變數聲明
聲明格式為: var 變數名;
var num;//聲明一個變數 var num1,num2;//聲明多個變數
用var操作符定義的變數將成為定義該變數的作用域中的局部變數。若省略var操作符,可以創建一個全局變數,但在嚴格模式下會拋出 ReferenceError錯誤
var num1=1; num2=2;//在嚴格模式下會報錯 num3;//報錯
如果重新聲明 JavaScript 變數,該變數的值不會丟失
var carname="Volvo"; console.log(carname);//Volvo var carname; console.log(carname);//Volvo
聲明提升
javascript中的變數聲明會提升到所有函數和語句之前,但提升後的變數將返回undefined,因為只是聲明提升,賦值操作並沒有提升
console.log(myvar); // undefined var myvar = "local value"; console.log(myvar); // "local value"
變數賦值
使用"="給變數賦值,也就是存儲內容。變數可以在聲明時賦值,但不能有其他操作,如+=、-=等
var num = 5; //上下是等價的 var num; num = 5;
var a = 2;//正確 var a += 2;//錯誤 var a = 2++;//錯誤,++只能用於變數,不能用於常量
標識符
標識符是指變數、函數、屬性的名字,或者函數的參數
標識符命名
命名規則同變數命名規則,對於不符合命名規則的屬性如border-color應寫為大括弧方式[borderColor]
標識符解析
標識符解析是沿著作用域鏈一級一級地搜索標識符的過程。搜索過程始終從作用域鏈的前端開始,然後逐級地向後回溯,直到找到標識符為止。
[1]如果局部環境中存在著同名標識符,就不會使用父環境中的標識符
[2]如果找不到標識符,表示標識符尚未聲明,通常會導致錯誤發生
[3]JavaScript引擎在優化標識符查詢方面做得不錯,訪問父環境和局部環境的標識符的時間差別可以忽略不計
var num = 1; function test(){ num = 2; console.log(num);//2 console.log(number);//報錯 } test();