当前位置: 首页 > Web前端 > JavaScript

基础-变量var-let-const

时间:2023-03-27 12:00:24 JavaScript

鍦‥S6鍑虹幇涔嬪墠锛宩s瀹氫箟鍙橀噺鐨勫敮涓€鍏抽敭瀛楀氨鏄痸ar銆俵et鍜宑onst鏄湪ES6涔嬪悗鍔犲叆鐨勩€傛柊鐨勫彉閲忓0鏄庡叧閿瓧鐨勫嚭鐜颁篃甯︽潵浜嗕竴浜涙柊鐨勫彉鍖栥€傚ソ濂戒韩鍙楀惂:)var鍦‥S6鍑虹幇涔嬪墠锛孞avaScript涓畾涔夊彉閲忕殑鍏抽敭瀛楀彧鏈塿ar澹版槑浣滅敤鍩熶娇鐢╲ar杩愮畻绗︽潵瀹氫箟涓€涓彉閲忥紝瀹冧細鎴愪负鍖呭惈瀹冪殑鍑芥暟鐨勫眬閮ㄥ彉閲忥紝涔熷氨鏄杩欎釜鍙橀噺灏嗗湪鍑芥暟閫€鍑烘椂鏄剧ず琚攢姣併€傚嚱鏁癴oo(){varname='foo';鎺у埗鍙版棩蹇楋紙鍚嶇О锛夛紱//foo}foo();console.log(鍚嶇О);//閿欒鍏ㄥ眬鍙橀噺濡傛灉瀹氫箟鍙橀噺鏃舵病鏈変娇鐢╲ar鍏抽敭瀛楋紝姝ゆ椂澹版槑鐨勫彉閲忓皢鎴愪负鍏ㄥ眬鍙橀噺銆俧unctionfoo(){//娌℃湁鍏抽敭瀛?var'name='foo';鎺у埗鍙版棩蹇楋紙鍚嶇О锛夛紱//foo}foo();console.log(鍚嶇О);//foo涓婇潰鐨勪唬鐮佷細鍙樻垚涓嬮潰鍦ㄤ笂闈㈢殑浠g爜涓紝鍙橀噺鍚嶇殑澹版槑鍦╣lobal.铏界劧鍙互閫氳繃杩欑鏂瑰紡澹版槑涓€涓叏灞€鍙橀噺锛屼絾鏄己鐑堜笉鎺ㄨ崘杩欑鏂瑰紡锛屽畠浼氭薄鏌撳叏灞€鍙橀噺锛屼娇浠g爜闅句互缁存姢銆傚彉閲忓悕绉帮紱functionfoo(){name='foo';}鍦ㄤ弗鏍兼ā寮忎笅锛屽鏋滀笉鐩存帴澹版槑璧嬪€兼搷浣滐紝浼氱洿鎺ユ姏鍑篟eferenceError寮傚父銆傛敼杩涙彁鍗囧湪寮€濮嬫湰鑺備箣鍓嶏紝璇疯€冭檻浠ヤ笅浠g爜灏嗘墦鍗颁粈涔堬紵浼氱洿鎺ユ姤閿欐姏鍑篍rror鍚楋紵鎴栬€呭畠浼氭甯告墦鍗板嚭foo鍚楋紵鎴栬€呭畠鏄湭瀹氫箟鐨勶紵鍑芥暟foo(){console.log(鍚嶇О);varname='foo';}鍦ㄥ洖绛斾箣鍓嶅厛鏄庣‘涓€涓嬶紝澹版槑鍜岃祴鍊煎叾瀹炴槸涓や釜鍔ㄤ綔銆傚綋鎴戜滑浣跨敤varname='foo'鏃讹紝鍏跺疄鍖呭惈浜嗕袱涓姩浣滐細澹版槑鍜岃祴鍊笺€傜涓€涓槸varname鐨勫0鏄庯紝澹版槑涓€涓猲ame鐨勫彉閲忥紝绗簩涓槸璧嬪€硷紝灏唍ame璧嬪€肩粰foo銆傜幇鍦ㄦ潵鍥炵瓟锛屼笂闈㈢殑浠g爜鏄笉浼氭姤閿欑殑銆傚綋var鐢ㄤ簬鍙橀噺澹版槑鏃讹紝鍙橀噺澹版槑浼氳嚜鍔ㄦ彁鍗囧埌鍑芥暟浣滅敤鍩熺殑椤堕儴锛岀劧鍚庢墦鍗板嚭鏉ャ€傛鏃秐ame杩樻槸涓€涓彉閲忥紝鍙槸澹版槑涓鸿祴鍊硷紝鎵€浠ユ鏃舵墦鍗皀ame浼氭墦鍗皍ndefined锛屼箣鍚庤繘琛屽彉閲忚祴鍊兼搷浣溿€傚惉璧锋潵浜戦噷闆鹃噷锛屼篃灏辨槸涓婇潰浠g爜鐨勫疄闄呮墽琛岄『搴忔槸杩欐牱鐨勶細functionfoo(){varname;鎺у埗鍙版棩蹇楋紙鍚嶇О锛夛紱//undefinedname='foo';}鎵€璋撳彉閲忔彁鍗囨槸鎸囧皢鎵€鏈夌殑鍙橀噺澹版槑鎻愬崌鍒板嚱鏁颁綔鐢ㄥ煙鐨勯《閮ㄣ€傚鏋滃0鏄庝簡澶氭锛屽彧瑕佸湪鍚屼竴涓綔鐢ㄥ煙鍐咃紝閲嶅浜嗕篃娌″叧绯汇€備絾璇锋敞鎰忥紝鍒嗛厤浠嶅皢淇濈暀鍦ㄥ師鍦般€傚崌鑱屽彧鏄鍛婏紝鍒嗛厤杩樻槸鎸夌収鍘熸潵鐨勯『搴忚繘琛屻€傚姛鑳絝oo(){console.log(鍚嶇О);//鏈畾涔夌殑鍙橀噺鍚?'foo';varname='閰掑惂';鎺у埗鍙版棩蹇楋紙鍚嶇О锛夛紱//鏍忓彉閲忓悕绉?'ba1r';鎺у埗鍙版棩蹇楋紙鍚嶇О锛夛紱//ba1rvarname='bar2';}let&constlet鍜宑onst鏄嚜ES6鍙戝竷浠ユ潵鏂板鐨勫彉閲忓畾涔夊叧閿瓧锛屼笌var鏈€澶х殑鍖哄埆鏄柊澧炵殑let鍜宑onst鏄潡绾т綔鐢ㄥ煙锛屼笉鏄嚱鏁拌寖鍥淬€傚潡浣滅敤鍩焞et鍜宑onst鏄潡浣滅敤鍩熺殑銆侸avaScript寮曟搸浼氳窡韪敤浜庡彉閲忓0鏄庣殑鏍囪瘑绗﹀強鍏跺潡浣滅敤鍩熴€傚潡绾т綔鐢ㄥ煙锛岄【鍚嶆€濅箟锛屽畠鐨勪綔鐢ㄥ煙浠呴檺浜庡潡鍐呴儴銆傚鏋滐紙鐪燂級{璁╁勾榫?30锛涙帶鍒跺彴鏃ュ織锛堝勾榫勶級锛?/30}console.log(age);//ReferenceError:ageisnotdefined蹇€熸彁闂細涓嬮潰鎵ц鐨勭粨鏋滄槸浠€涔堬紵浣犲彲浠ヨ嚜宸辫瘯璇曘€倇leta=42;}console.log(a);//?Nohoisting&TDZTemporarydeadzone閫氳繃var澹版槑鐨勫彉閲忓彲浠ラ噸澶嶅0鏄庯紝鐢变簬鎻愬崌锛屾墍鏈夊彉閲忓0鏄庡皢琚彁鍗囧埌鍩熺殑鍑芥暟椤堕儴锛屾墍浠ュ嵆浣块噸澶嶅0鏄庝篃鍙互銆備笌var涓嶅悓锛宭et鍜宑onst鍙橀噺澹版槑涓嶄細鎻愬崌鍒拌寖鍥村唴銆傚湪瑙f瀽浠g爜鏃讹紝JavaScript寮曟搸浼氭敞鎰忓埌鍧椾綔鐢ㄥ煙涓細鏈変竴涓猯et璇彞锛屽湪鎵ц鐩稿簲鐨勮鍙ヤ箣鍓嶏紝涓嶈兘浠ヤ换浣曟柟寮忓紩鐢ㄦ湭澹版槑鐨勫彉閲忋€傝繖瀵艰嚧浜嗕复鏃舵鍖虹殑姒傚康銆俆DZ锛坱emporaldeadzone锛塗DZ鏄疎S6瑙勮寖涓畾涔夌殑涓€涓柊姒傚康锛屾寚鐨勬槸浠g爜涓殑鍙橀噺鍥犱负娌℃湁琚垵濮嬪寲鑰屾棤娉曡寮曠敤鐨勬儏鍐点€傚湪鎵ц鐩稿簲鐨勮鍙ヤ箣鍓嶏紝涓嶈兘浠ヤ换浣曟柟寮忓紩鐢ㄦ湭澹版槑鐨勫彉閲忋€傚洜姝わ紝鍦ㄥ潡绾т綔鐢ㄥ煙鎵ц鍒板搴旂殑let璇彞涔嬪墠锛岀О涓轰复鏃舵鍖猴紙temporaldeadzone锛孴DZ锛夈€備緥濡傦紝鍦ㄤ笅闈㈢殑浠g爜涓紝濡傛灉鍦ㄦ墽琛宎ge鐨勫疄闄呭0鏄庝箣鍓嶅紩鐢ㄤ簡鍙橀噺age锛屽垯浼氭姏鍑篟eferenceError銆傚鏋滐紙鐪燂級{console.log锛堝勾榫勶級锛?/ReferenceError:鍦ㄥ垵濮嬪寲涔嬪墠鏃犳硶璁块棶'age'letage=30;}鍚屾牱锛屽嚱鏁板弬鏁伴噸鏂颁紶閫掔殑杩囩▼涓篃瀛樺湪鎵€璋撶殑鈥滄鍖衡€濓紝渚嬪Example馃尠functionbar(x=y,y=2){...}姝ゆ椂锛寉杩樻病鏈夎繕娌℃湁澹版槑锛屾墍浠ヨ繖鏍风殑鍙傛暟澹版槑浼氭姤閿欍€備絾鏄笅闈㈣繖绉嶆儏鍐碉紝x鍜寉鐨勯『搴忔槸棰犲€掔殑锛岃闂畒鐨勬椂鍊欐濂借法瓒婁簡x鐨凾DZ锛屾墍浠鐨勮繖绉嶈闂柟寮忔槸娌℃湁闂鐨勩€俧unctionbar(x=2,y=x){...}鐢变簬瑕佹眰const鍙橀噺鍦ㄥ0鏄庢椂绔嬪嵆鍒濆鍖栵紝鎵€浠ヤ笉瀛樺湪TDZ闂銆俫lobaldeclarationvar鍦ㄥ叏灞€鑼冨洿鍐呭0鏄庣殑鍙橀噺灏嗘垚涓簑indow瀵硅薄鐨勫睘鎬э紱whilelet鍦ㄥ叏灞€鑼冨洿鍐呭0鏄庣殑鍙橀噺涓嶄細鎴愪负绐楀彛瀵硅薄鐨勫睘鎬с€備絾鐩稿悓鐨勬槸锛屽彂鐢熷湪鍏ㄥ眬鑼冨洿鍐呯殑澹版槑浼氬湪鐢熷懡鍛ㄦ湡涓寔涔呭寲銆傚洜姝わ紝let蹇呴』淇濊瘉鍚屼竴涓彉閲忎笉浼氳澹版槑涓ゆ銆倀ypeof&try...catch鐨勯櫡闃辨墠鏄噸鐐癸紒let鍜宑onst鏄潡浣滅敤鍩熺殑銆傚湪涓嬮潰鐨勪緥瀛愪腑锛宭et鐨勫0鏄庝細琚檺鍒跺湪瀵瑰簲鐨勫潡绾ц寖鍥村唴锛屾墍浠ユ棤娉曡揪鍒板搴旂殑鏉′欢澹版槑鐨勬晥鏋溿€俰f(typeofname==='undefined'){璁╁悕瀛?//name鍙瓨鍦ㄤ簬if{...}}try{console.log(age);}catch{letage=25;鎺у埗鍙版棩蹇楋紙骞撮緞锛夛紱//age鍙瓨鍦ㄤ簬catch}寰幆宸ュ叿鎴戜滑缁忓父鐪嬪埌涓€閬撻潰璇曢锛屼細鎵撳嵃鍑轰粈涔堛€俧or(vari=0;i<5;i++){setTimeout(()=>{console.log(i);//5,5,5,5,5},200);}杩欐槸鍥犱负锛屼娇鐢ㄥ鏋滆缃簡瀹氭椂鍣紝鎵撳嵃浼氬欢杩熴€傝€寁ar澹版槑鐨勫彉閲忔槸functionscope锛宨宸茬粡鍒颁簡5銆傚綋timer鐪熸璁板綍鐨勬椂鍊欙紝瀹為檯涓婂凡缁忔墽琛屼簡寰幆锛屾墍浠ユ墦鍗板嚭5涓?銆傚鏋滄垜浠敼涓鸿澹版槑杩唬鍙橀噺锛屾垜浠皢鑳藉鎵撳嵃0,1,2,3,4銆傝繖鏄洜涓猴紝鍦ㄤ娇鐢╨et涔嬪悗锛屾瘡娆¤凯浠g殑鑼冨洿琚檺鍒跺湪for寰幆鍧楀唴銆侸avaScript寮曟搸涓烘瘡涓€娆¤凯浠e惊鐜兘澹版槑浜嗕竴涓柊鐨勮凯浠e彉閲忥紝鎵€浠ユ瘡涓€涓畾鏃跺櫒閮藉紩鐢ㄤ簡涓€涓笉鍚岀殑鍙橀噺瀹炰緥锛屽嵆寰幆鎵ц杩囩▼涓瘡涓€涓凯浠e彉閲忕殑鍊笺€俧or(leti=0;i<5;i++){setTimeout(()=>{console.log(i);//0,1,2,3,4},200);}甯搁噺鎬庝箞鏀緇et鍜宑onst骞舵帓銆備絾鏄紝let鍜宑onst涔嬮棿涔熷瓨鍦ㄧ粏寰樊鍒€備富瑕佸尯鍒粠const杩欎釜璇嶅氨鍙互鐪嬪嚭鏉ワ紝const鐨勬剰鎬濇槸constant锛屽氨鏄父閲忕殑鎰忔€濓紝鐢╟onst澹版槑鐨勫彉閲忓叿鏈変笉鍙彉鎬э紝鎴愪负鈥滃父閲忊€濄€俵et鍜宑onst鐨勮涓烘渶澶х殑鍖哄埆鏄痗onst鐨勫0鏄庡拰璧嬪€煎繀椤诲悓鏃惰繘琛屻€傝瘯鍥句慨鏀筩onst澹版槑鐨勫彉閲忓皢瀵艰嚧杩愯鏃堕敊璇€備絾鏄紝const澹版槑鐨勯檺鍒朵粎閫傜敤浜庡鍏舵寚鍚戠殑鍙橀噺鐨勫紩鐢ㄣ€傛崲鍙ヨ瘽璇达紝濡傛灉涓€涓猚onst鍙橀噺寮曠敤涓€涓璞★紝閭d箞淇敼瀵硅薄鍐呴儴灞炴€х殑鍊煎苟涓嶈繚鍙峜onst闄愬埗銆傚父閲廰=2;a=3;//TypeError:璧嬪€肩粰甯搁噺variable.constobj={a:2}obj.a=4;//娌″叧绯籗ummaryES6鏂板let鍜宑onst甯姪JavaScript绀惧尯瑙e喅闀挎湡瀛樺湪鐨剉ar鎬紓鎵ц鏂瑰紡甯︽潵鐨勪竴绯诲垪鍥版壈銆俵et鍜宑onst杩欎袱涓潡绾т綔鐢ㄥ煙鍙橀噺澹版槑鍏抽敭瀛楋紝鍙互鍦ㄥ紑鍙戣繃绋嬩腑瀵瑰彉閲忓0鏄庣殑浣滅敤鍩熷拰璇箟鎻愪緵鏇寸簿鍑嗙殑鏀寔锛屾湁鍔╀簬寮€鍙戣繃绋嬩腑鐨勪唬鐮佺悊瑙e拰浠g爜璐ㄩ噺鎻愬崌銆傚湪瀹為檯寮€鍙戣繃绋嬩腑锛屾洿鎻愬€′娇鐢╨et鍜宑onst锛岃繖鏍峰彲浠ヤ娇鍙橀噺鐨勫0鏄庡拰浣跨敤鏇村叿棰勮鎬с€傚悓鏃讹紝寤鸿鍙湪寮€鍙戣€呮湡鏈涙敼鍙樺彉閲忔椂鎵嶄娇鐢╨et锛岃繖鏍锋洿鏈夊埄浜庨棶棰樼殑鍙戠幇鍜岃В鍐炽€傜畝鍗曟€荤粨涓€涓嬶紝var銆乴et鍜宑onst鐨勫紓鍚岀偣銆侱eclarativemethodscopehoistinghoistinginitializationvarfunctionscopeusingvar灏嗗彉閲忓0鏄庢彁鍗囧埌鍑芥暟浣滅敤鍩熺殑椤堕儴鍙互澹版槑鐒跺悗鍒濆鍖杔et鍧楃骇浣滅敤鍩熶笉浼氳鎻愬崌鍙互澹版槑鐒跺悗鍒濆鍖朿onst鍧楃骇浣滅敤鍩熷皢not浼氬崌绾э紝蹇呴』鍚屾椂鍒濆鍖栥€傚弬鑰僇avaScript楂樼骇绋嬪簭璁捐锛堢4鐗堬級鈥斺€旂3绔犱綘鎵€涓嶇煡閬撶殑JavaScript鍗封€斺€旂5绔?/p>