日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

javascript中错误使用var造成undefined

發布時間:2025/5/22 javascript 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 javascript中错误使用var造成undefined 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

在javascript中依據變量作用的范圍不同分為局部變量和全局變量,直接定義的變量是全局變量,全局變量能夠被全部的腳本訪問;在函數中定義的變量是局部變量,局部變量僅僅在函數內有效。

假設全局變量和局部變量使用同樣的變量名,則局部變量將會覆蓋全局變量。

樣例代碼:

<!DOCTYPE html> <html><head><meta charset="utf-8"><title>js中全局變量與局部變量</title></head><body><script type="text/javascript">var a = "全局變量";function test1(){var a = "局部變量";alert(a);}function test2(){alert(a);var a = "局部變量";alert(a);}function test3(){alert(a);a = "局部變量";alert(a);}</script><input type="button" value="test1" οnclick="test1()"/><input type="button" value="test2" οnclick="test2()"/><input type="button" value="test3" οnclick="test3()"/></body> </html>

執行的結果是這種:

點擊test1 ,彈出局部變量。

點擊test2,彈出undefined,再彈出局部變量

? 點擊test3,彈出全局變量,再彈出局部變量


這就是使用var和不使用的差別所在:

假設使用var,那么程序會強制定義一個新變量。

假設沒有使用var,系統會優先在當前上下文中搜索是否存在該變量,僅僅有在不存在的前提下才會又一次定義一個新變量。


test3中,使用的變量a均為全局變量,第一次直接輸出了全局變量,第二次是直接為全局變量賦值之后使用。

test1和test2中都存在在function中使用var定義同名新變量,會導致函數中的變量覆蓋掉全局變量。所以在test2中:第一次輸出的a是已經被覆蓋了的局部變量a,可是沒有給予初值,所以會出現undefined這個結果。這樣使用變量實際上是錯誤的,大家應該避免。



轉載于:https://www.cnblogs.com/bhlsheji/p/4065794.html

總結

以上是生活随笔為你收集整理的javascript中错误使用var造成undefined的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。