let 和const

1歉胶、let
6新加了let命令罕拂,用來聲明變量随闺,和var類似现拒。
但其聲明的變量只在let命令所在代碼塊內訪問,之外訪問不了灌砖。
{
let a=1;
var b=1;
}
console.log(a,b) // a not defined
它可用于for循環(huán)中
var a=[];
for(let i=0;i<10;i++){
a[i]=function(){
console.log(i):
}

a6;//輸出6
在每次for循環(huán)時i 都會一個新的變量璧函,i只在本地循環(huán)中可用。
它只在本地循環(huán)的塊中可訪問基显。
let 使用前必須先申明柳譬。
暫時性死區(qū):
只要塊級內有l(wèi)et命令,它所聲明的變量會綁定在這個塊上续镇,不受外部影響美澳。
var tmp = 123;
if (true) {
tmp = 'abc';
let tmp;
}
解析:這里全局有個tmp在塊內賦值了,后才創(chuàng)建的let tmp摸航。
在此塊內創(chuàng)建了let 制跟,但在申明前使用了它會報錯的。
es6明確規(guī)定酱虎,如果塊內存在let const ,這些變量會形成封閉作用域雨膨,凡是在聲明前使用都會報錯。
如果當全局內和塊內的let名稱一樣读串,先使用變量是不會向上級查找的聊记。
不允許重復聲明:
let在塊內不允許重復聲明同樣的變量。
Let a;
var a;
這時var 會報錯恢暖。
當然函數內的聲明不能和參數名一樣排监。
2、塊級作用域
為什么需要呢杰捂?
es5里只有全局作用域和函數作用域舆床,是沒有塊級作用域的。
問題1:
var tmp = new Date();
function f(){
console.log(tmp);
if (false){
var tmp = "hello world";
}
}
f() // undefined
執(zhí)行后會輸出未定義
原因是函數內的聲明變量提升,在訪問時會輸出未定義挨队,而不會到全局去找變量谷暮。
這樣內部變量覆蓋了對全局的訪問。
問題2:
for(var i=0;i<10;i++){}
console.log(i); //9
for 循環(huán)定義的i 在結束后還能訪問到盛垦。
所以let實現了塊級作用域湿弦。
function fn(){
let n=5;
if(true){
let n=10;
}
console.log(n)//5
}
因為有了塊作用域if內的let不會覆蓋到外部的。
es5允許塊作用域任意嵌套腾夯。
{{{let a=1;}}}
塊作用域的出現使得立即執(zhí)行函數沒那么重要了省撑。
函數中的function 函數會提升,會覆蓋掉全局的訪問俯在。這是es5時
es6是不會的竟秫。
聲明的let 在塊是可以訪問和修改的。
3跷乐、const命令
它聲明的是常量肥败。不需要改變的值。
聲明時必須要賦值的.
const的作用域和let一樣的愕提。
在聲明復合類型的常量時馒稍,變量名指向的是數據的地址.
const命令只保證常量指定的地址不變,并不保證地址指向的數據不變浅侨。
const a=[];
a.push(1);
a=[1,2]
賦值會報錯
可以將對象凍結纽谒,來實現不允許修改對象。
const a=Object.freeze({});
a.name=Xx;
添加屬性時會報錯如输。
上邊創(chuàng)建一個凍結的對象鼓黔,不可對其操作的。
4不见、跨模塊常量使用
const聲明的常量只能在當前代碼使用澳化,當然也可跨模塊使用
// constants.js 模塊
export const A = 1;
export const B = 3;
export const C = 4;

// test1.js 模塊
import * as constants from './constants';
console.log(constants.A); // 1
console.log(constants.B); // 3

// test2.js 模塊
import {A, B} from './constants';
console.log(A); // 1
console.log(B); // 3

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市稳吮,隨后出現的幾起案子缎谷,更是在濱河造成了極大的恐慌,老刑警劉巖灶似,帶你破解...
    沈念sama閱讀 218,284評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件列林,死亡現場離奇詭異,居然都是意外死亡酪惭,警方通過查閱死者的電腦和手機希痴,發(fā)現死者居然都...
    沈念sama閱讀 93,115評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來撞蚕,“玉大人润梯,你說我怎么就攤上這事∩茫” “怎么了纺铭?”我有些...
    開封第一講書人閱讀 164,614評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長刀疙。 經常有香客問我舶赔,道長,這世上最難降的妖魔是什么谦秧? 我笑而不...
    開封第一講書人閱讀 58,671評論 1 293
  • 正文 為了忘掉前任竟纳,我火速辦了婚禮,結果婚禮上疚鲤,老公的妹妹穿的比我還像新娘锥累。我一直安慰自己,他們只是感情好集歇,可當我...
    茶點故事閱讀 67,699評論 6 392
  • 文/花漫 我一把揭開白布桶略。 她就那樣靜靜地躺著,像睡著了一般诲宇。 火紅的嫁衣襯著肌膚如雪际歼。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,562評論 1 305
  • 那天姑蓝,我揣著相機與錄音鹅心,去河邊找鬼。 笑死纺荧,一個胖子當著我的面吹牛旭愧,可吹牛的內容都是我干的。 我是一名探鬼主播宙暇,決...
    沈念sama閱讀 40,309評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼榕茧,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了客给?” 一聲冷哼從身側響起用押,我...
    開封第一講書人閱讀 39,223評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎靶剑,沒想到半個月后蜻拨,有當地人在樹林里發(fā)現了一具尸體,經...
    沈念sama閱讀 45,668評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡桩引,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,859評論 3 336
  • 正文 我和宋清朗相戀三年缎讼,在試婚紗的時候發(fā)現自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片坑匠。...
    茶點故事閱讀 39,981評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡血崭,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情夹纫,我是刑警寧澤咽瓷,帶...
    沈念sama閱讀 35,705評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站舰讹,受9級特大地震影響茅姜,放射性物質發(fā)生泄漏。R本人自食惡果不足惜月匣,卻給世界環(huán)境...
    茶點故事閱讀 41,310評論 3 330
  • 文/蒙蒙 一钻洒、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧锄开,春花似錦素标、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至退腥,卻和暖如春任岸,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背狡刘。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評論 1 270
  • 我被黑心中介騙來泰國打工享潜, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人嗅蔬。 一個月前我還...
    沈念sama閱讀 48,146評論 3 370
  • 正文 我出身青樓剑按,卻偏偏與公主長得像,于是被迫代替她去往敵國和親澜术。 傳聞我的和親對象是個殘疾皇子艺蝴,可洞房花燭夜當晚...
    茶點故事閱讀 44,933評論 2 355

推薦閱讀更多精彩內容

  • let 命令 塊級作用域 const 命令 頂層對象的屬性 global 對象 let 命令 基本用法 ES6 新...
    嘉奇呦_nice閱讀 1,630評論 0 2
  • let 和 const 命令 let 命令 塊級作用域 const 命令 頂層對象的屬性 gl...
    安小明閱讀 981評論 0 0
  • let 命令 塊級作用域 const 命令 頂層對象的屬性 global 對象 let 命令 基本用法 ES6 新...
    卞卞村長L閱讀 595評論 0 0
  • let 基本用法 let命令,用來聲明變量鸟废。用法類似于var猜敢,但聲明的變量,只在let命令所在的代碼塊內有效盒延。 f...
    oWSQo閱讀 438評論 0 0
  • 最近喜歡上了騎單車缩擂。近期北京有好多的摩拜單車供大家騎行。 騎自行車在路上有種特殊的感覺添寺。覺得自己是活的胯盯,有呼吸的存...
    靖溪閱讀 397評論 0 0