精品视频123区在线观看_少妇按摩一区二区三区_91亚洲精选_91老司机在线_久久大综合网_97超碰在线资源_亚洲午夜久久久久久久久电影院_日韩欧美一区二区三区视频

二維碼
企資網

掃一掃關注

當前位置: 首頁 » 企資快訊 » 匯總 » 正文

說說var_let_const之間的區別

放大字體  縮小字體 發布日期:2023-01-28 23:36:25    作者:葉語韓    瀏覽次數:97
導讀

var在ES5中,頂層對象得屬性和全局變量是等價得,用var聲明得變量既是全局變量,也是頂層變量注意:頂層對象,在瀏覽器環境指得是window對象,在 Node 指得是global對象var a = 10;console.log(window.a) // 10使用v

var

在ES5中,頂層對象得屬性和全局變量是等價得,用var聲明得變量既是全局變量,也是頂層變量

注意:頂層對象,在瀏覽器環境指得是window對象,在 Node 指得是global對象

var a = 10;console.log(window.a) // 10

使用var聲明得變量存在變量提升得情況

console.log(a) // undefinedvar a = 20

在編譯階段,編譯器會將其變成以下執行

var aconsole.log(a)a = 20

使用var,我們能夠對一個變量進行多次聲明,后面聲明得變量會覆蓋前面得變量聲明

var a = 20 var a = 30console.log(a) // 30

在函數中使用使用var聲明變量時候,該變量是局部得

var a = 20function change(){ var a = 30}change()console.log(a) // 20

而如果在函數內不使用var,該變量是全局得

var a = 20function change(){ a = 30}change()console.log(a) // 30 let

let是ES6新增得命令,用來聲明變量

用法類似于var,但是所聲明得變量,只在let命令所在得代碼塊內有效

{ let a = 20}console.log(a) // ReferenceError: a is not defined.

不存在變量提升

console.log(a) // 報錯ReferenceErrorlet a = 2

這表示在聲明它之前,變量a是不存在得,這時如果用到它,就會拋出一個錯誤

只要塊級作用域內存在let命令,這個區域就不再受外部影響

var a = 123if (true) { a = 'abc' // ReferenceError let a;}

使用let聲明變量前,該變量都不可用,也就是大家常說得“暫時性死區”

最后,let不允許在相同作用域中重復聲明

let a = 20let a = 30// Uncaught SyntaxError: Identifier 'a' has already been declared

注意得是相同作用域,下面這種情況是不會報錯得

let a = 20{ let a = 30}

因此,我們不能在函數內部重新聲明參數

function func(arg) { let arg;}func()// Uncaught SyntaxError: Identifier 'arg' has already been declaredconst

const聲明一個只讀得常量,一旦聲明,常量得值就不能改變

const a = 1a = 3// TypeError: Assignment to constant variable.

這意味著,const一旦聲明變量,就必須立即初始化,不能留到以后賦值

const a;// SyntaxError: Missing initializer in const declaration

如果之前用var或let聲明過變量,再用const聲明同樣會報錯

var a = 20let b = 20const a = 30const b = 30// 都會報錯

const實際上保證得并不是變量得值不得改動,而是變量指向得那個內存地址所保存得數據不得改動

對于簡單類型得數據,值就保存在變量指向得那個內存地址,因此等同于常量

對于復雜類型得數據,變量指向得內存地址,保存得只是一個指向實際數據得指針,const只能保證這個指針是固定得,并不能確保改變量得結構不變

const foo = {};// 為 foo 添加一個屬性,可以成功foo.prop = 123;foo.prop // 123// 將 foo 指向另一個對象,就會報錯foo = {}; // TypeError: "foo" is read-only

其它情況,const與let一致

區別

var、let、const三者區別可以圍繞下面五點展開:

變量提升暫時性死區塊級作用域重復聲明修改聲明得變量使用變量提升

var 聲明得變量存在變量提升,即變量可以在聲明之前調用,值為undefined

let和const不存在變量提升,即它們所聲明得變量一定要在聲明后使用,否則報錯

// varconsole.log(a) // undefinedvar a = 10// let console.log(b) // Cannot access 'b' before initializationlet b = 10// constconsole.log(c) // Cannot access 'c' before initializationconst c = 10暫時性死區

var不存在暫時性死區

let和const存在暫時性死區,只有等到聲明變量得那一行代碼出現,才可以獲取和使用該變量

// varconsole.log(a) // undefinedvar a = 10// letconsole.log(b) // Cannot access 'b' before initializationlet b = 10// constconsole.log(c) // Cannot access 'c' before initializationconst c = 10塊級作用域

var不存在塊級作用域

let和const存在塊級作用域

// var{ var a = 20}console.log(a) // 20// let{ let b = 20}console.log(b) // Uncaught ReferenceError: b is not defined// const{ const c = 20}console.log(c) // Uncaught ReferenceError: c is not defined重復聲明

var允許重復聲明變量

let和const在同一作用域不允許重復聲明變量

// varvar a = 10var a = 20 // 20// letlet b = 10let b = 20 // Identifier 'b' has already been declared// constconst c = 10const c = 20 // Identifier 'c' has already been declared修改聲明得變量

var和let可以

const聲明一個只讀得常量。一旦聲明,常量得值就不能改變

// varvar a = 10a = 20console.log(a) // 20//letlet b = 10b = 20console.log(b) // 20// constconst c = 10c = 20console.log(c) // Uncaught TypeError: Assignment to constant variable使用

能用const得情況盡量使用const,其他情況下大多數使用let,避免使用var

 
(文/葉語韓)
免責聲明
本文僅代表作發布者:葉語韓個人觀點,本站未對其內容進行核實,請讀者僅做參考,如若文中涉及有違公德、觸犯法律的內容,一經發現,立即刪除,需自行承擔相應責任。涉及到版權或其他問題,請及時聯系我們刪除處理郵件:weilaitui@qq.com。
 

Copyright ? 2016 - 2025 - 企資網 48903.COM All Rights Reserved 粵公網安備 44030702000589號

粵ICP備16078936號

微信

關注
微信

微信二維碼

WAP二維碼

客服

聯系
客服

聯系客服:

在線QQ: 303377504

客服電話: 020-82301567

E_mail郵箱: weilaitui@qq.com

微信公眾號: weishitui

客服001 客服002 客服003

工作時間:

周一至周五: 09:00 - 18:00

反饋

用戶
反饋

成年女人免费又黄又爽视频| 免费看电影在线| 在线观看免费黄色小视频| 久久免费区一区二区三波多野| 欧美精品videossex少妇| 一区二区在线不卡| 亚洲免费看片| 欧美亚洲激情在线| 精品亚洲乱码一区二区| chinese偷拍一区二区三区| 精品久久久久久中文字幕| 亚洲aaa在线观看| 亚洲激情在线观看| 调教视频免费在线观看| 日韩精品视频久久| 亚洲精品一二三区| 最近中文字幕av| 久久综合久久鬼色| www.啪啪.com| 成人免费毛片片v| 亚洲一级av无码毛片精品| а√天堂中文在线资源bt在线| 青草成人免费视频| 国产精品日本一区二区不卡视频| 国产精品久久夜| 无码av免费精品一区二区三区| 国产精品豆花视频| 免费在线观看污网站| aa在线视频| 欧美日韩无遮挡| 欧美一区二区三区久久精品茉莉花 | 国产欧美中文在线| 蜜臀av免费在线观看| 国产精品国模大尺度私拍| 成人av在线一区二区三区| 99热只有这里有精品| 日韩中文字幕视频在线| 欧美视频免费看| 久久中文字幕在线视频| 中文字幕黄色片| 精品国产精品网麻豆系列| 黄色动漫在线观看| 国产成人在线小视频| 国产原创一区二区三区| 欧美综合激情| 欧美www视频在线观看| 欧美激情一区二区三区免费观看 | 中文字幕在线第一页| 午夜av电影一区| 中文字幕一二区| 五月天av在线| 99re6在线| 麻豆成全视频免费观看在线看| av免费在线播放网站| 国产一区亚洲一区| 成人在线免费公开观看视频| 中文字幕网站在线观看| 欧美成年人视频| 中文字幕综合| а天堂中文在线资源| 成人另类视频| 波多野结衣理论片| 欧美精品激情在线| 欧美私人啪啪vps| 国产日韩欧美在线播放| 欧美97人人模人人爽人人喊视频| 伦伦影院午夜理论片| 久久久久久免费精品| 欧美精品一区二区久久| 国产日韩在线免费观看| 久久综合免费视频| 成人系列视频| 日韩专区第三页| 性久久久久久久久久久久| 日韩免费va| 国产精品爱啪在线线免费观看| 国产黑丝在线一区二区三区| aaa在线播放视频| 精品人妻无码一区二区色欲产成人| 午夜老司机精品| 欧美日韩综合在线| 电影一区电影二区| 五月婷婷亚洲综合| 免费91在线视频| 国内在线观看一区二区三区| 国产乱在线观看视频| 国产日韩欧美精品在线观看| 欧美午夜一区二区三区免费大片| 免费全黄无遮挡裸体毛片| 欧美日韩中文精品| 视频精品导航| 精品xxxxxbbbb欧美中文| 亚洲品质视频自拍网| 日本三级视频网站| 久久艹在线视频| 玖玖玖国产精品| av免费看网址| 亚洲欧美视频在线| 国语自产精品视频在线看抢先版结局| 小早川怜子一区二区的演员表| 亚洲 自拍 另类小说综合图区| 2018日韩中文字幕| 午夜日韩视频| 麻豆传媒在线免费看| 黑人巨大精品一区二区在线| 91精品在线国产| wwwwww.欧美系列| 国产亚洲欧美在线精品| 国产精品视频免费一区二区三区| 中文字幕日本乱码精品影院| 亚洲自拍偷拍图| 456亚洲精品成人影院| 中文字幕一区二区三区四区免费看 | 日韩视频亚洲视频| 亚洲伦理精品| 捆绑裸体绳奴bdsm亚洲| 欧美调教femdomvk| 日韩电影免费网址| 亚洲字幕成人中文在线观看| 日韩三级小视频| 精品成人一区二区三区| 欧美亚洲在线日韩| 亚洲第一色网| 一区二区三区我不卡| 777午夜精品视频在线播放| 亚洲精品人成电影网| 欧美 日韩精品| 99视频在线精品| 性网站在线播放| 日韩欧美精品在线不卡| 一区二区91| 1024亚洲| 亚洲av成人无码久久精品| 7777免费精品视频| 久久久综合精品| 亚洲乱码在线| 成人久久久精品国产乱码一区二区| 精品一区二区三区日本| 国产麻豆成人精品| 日日夜夜天堂| 性中国xxx极品hd| 国产乱码一区二区| 在线观看中文字幕av| 九九九九九伊人| 免费成人在线视频网站| 亚洲欧美国产高清va在线播| 日韩精品在线看片z| 欧美一级久久久| 日韩限制级电影在线观看| 日韩欧美电影一二三| 91视频免费看| 久久国产欧美日韩精品| av激情成人网| 久久久男人天堂| 天堂av在线免费观看| 亚洲AV无码国产精品午夜字幕| 九九热免费在线观看| 日韩欧美精品在线不卡| 亚洲国产精品资源| 一本色道**综合亚洲精品蜜桃冫| 国模私拍视频在线播放| 日本免费看黄| 丰满人妻一区二区三区免费| 91丨porny丨对白| 99伊人久久| 欧美日韩国产一级二级| 91麻豆国产自产在线观看| 国产麻豆精品久久| 在线网址91| 天天添天天操| 国产日韩在线观看一区| 国产资源第一页| 国产精品美女主播| 久久99精品久久久久久琪琪| 成人黄色av| 99re6在线精品视频免费播放| 午夜视频在线观看韩国| 久久精品无码一区二区日韩av| 色欲av永久无码精品无码蜜桃| 久久视频免费在线观看| 日本男女交配视频| 欧美一区二区激情| 一区二区成人国产精品 | 毛片免费在线| 成年人网站免费观看| 女人18毛片一区二区三区| 一起操在线播放| 老熟妇精品一区二区三区| 免费视频网站www| 久草一区二区| 亚洲欧美国产高清va在线播| 成人免费在线视频| av不卡在线观看| 久久免费的精品国产v∧| 国产三级三级三级精品8ⅰ区| 欧美91精品久久久久国产性生爱| 国产熟女一区二区丰满| 原谅我中文字幕| 欧美一区二区三区免费观看| 一区二区三区产品免费精品久久75|