您的位置:首頁技術文章
文章詳情頁

JS變量提升原理與用法實例淺析

瀏覽:87日期:2024-05-07 16:03:53

本文實例講述了JS變量提升。分享給大家供大家參考,具體如下:

該篇介紹什么是變量提升,寫給像我一樣的JS新手看的

簡單來說變量提升就是 JS會把var變量的聲明自動提升到作用域的頂部,即使你不想這樣

一個例子: (局部變量與全局變量同名時 , 局部變量覆蓋全局變量)

var a='全局變量';function test(){ document.writeln(a); var a='局部變量'; document.writeln(a);}test();

上例的兩個輸出結果是

undefined局部變量

第一個輸出并沒有輸出全局變量a而是undefined ,這就是變量提升導致的

上例等同與下例:

var a='全局變量';function test(){ var a; document.writeln(a); a='局部變量'; document.writeln(a);}test();

test函數內即使局部變量a還沒定義,就已經覆蓋了全局變量,可見其聲明已經生效了,

變量聲明會自動提升到作用域的頂部, 即使該語句并沒執行

如下例:

var x=100;var y=200;function test(){ document.writeln(x); document.writeln(y); if(false) { var x=1; } return; var y=2;}test();

輸出結果:

undefinedundefined

等同如下形式:

var x=100;var y=200;function test(){ var x,y; document.writeln(x); document.writeln(y); if(false) { x=1; } return; y=2;}test();

那么怎么解決這個問題呢?

用let變量!let變量執行到定義部分才會裝載,具體用法請自行查詢!

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼運行效果。

更多關于JavaScript相關內容可查看本站專題:《JavaScript常用函數技巧匯總》、《javascript面向對象入門教程》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》及《JavaScript數學運算用法總結》

希望本文所述對大家JavaScript程序設計有所幫助。

標簽: JavaScript
相關文章:
国产综合久久一区二区三区