首頁 web前端 js教程 JavaScript全域變數宣告與優缺點介紹

JavaScript全域變數宣告與優缺點介紹

Jul 18, 2017 am 09:17 AM
javascript js 優缺點

JavaScript中宣告全域變數主要分為明確宣告或隱含宣告:

#宣告方式一:

##使用var(關鍵字)+變數名(標識符)的方式在function外部聲明,即為全域變量,否則在function聲明的是局部變數。此方式即為明確宣告詳細如下:

<script> 
  var test = 5;//全局变量 
  function a(){ 
    var a = 3;//局部变量 
    alert(a); 
  } 
  function b(){ 
    alert(test); 
  } 
  //a();//调用a方法,那么方法里面的内容才会执行 
  //b();//同上 
</script>
登入後複製

宣告方式二:

沒有使用var,直接給予識別碼test賦值,這樣會隱式的宣告了全域變數test。即使該語句是在一個function內,當該function被執行後test變成了全域變數。

<script> 
    test = 5;//全局变量 
    function a(){ 
      aa = 3;//也是全局变量 
      alert(test); 
    } 
    //a();  //输出5 
    //alert(aa);//这里也可以方法a()方法里面的变量,因为aa是全局变量 
  </script>
登入後複製

聲明方式三:

使用window全域物件來聲明,全域物件的屬性對應也是全域變量,詳細如下:

<script> 
  window.test = 50; 
  alert(test);//输出50 
</script>
登入後複製

這種方式常被用到一個匿名函數執行後將一些函數公開到全域。 如JQuery1.5中最末一句

程式碼如下:

window.jQuery = window.$ = jQuery;
登入後複製

全域變數的優點:

可以減少變數的個數,減少由於實際參數和形式參數的資料傳遞所帶來的時間消耗。

全域變數的缺點:

(1)全域變數保存在靜態存貯區,程式開始執行時為其分配內存,程式結束釋放該記憶體。與局部變數的動態分配、動態釋放相比,生存期比較長,因此過多的全域變數會佔用較多的記憶體單元。

(2)全域變數破壞了函數的封裝效能。函數像一個黑盒子,一般是透過函數參數和回傳值進行輸入輸出,函數內部實現相對獨立。但函數中如果使用了全局變量,那麼函數體內的語句就可以繞過函數參數和返回值進行訪問,這種情況破壞了函數的獨立性,使函數對全局變量產生依賴。同時,也降低了此函數的可移植性。

(3)全域變數使函數的程式碼可讀性降低。由於多個函數都可能使用全域變量,函數執行時全域變數的值可能隨時會變化,對於程式的查錯和除錯都非常不利。
因此,如果不是萬不得已,最好不要使用全域變數。

JS判斷變數是否為空是否null的方法

function isNull(data){
return (data == "" || data == undefined || data == null) ? "暂无" : data;
}
登入後複製

以上是JavaScript全域變數宣告與優缺點介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

建議:優秀JS開源人臉偵測辨識項目 建議:優秀JS開源人臉偵測辨識項目 Apr 03, 2024 am 11:55 AM

人臉偵測辨識技術已經是一個比較成熟且應用廣泛的技術。而目前最廣泛的網路應用語言非JS莫屬,在Web前端實現人臉偵測辨識相比後端的人臉辨識有優勢也有弱勢。優點包括減少網路互動、即時識別,大大縮短了使用者等待時間,提高了使用者體驗;弱勢是:受到模型大小限制,其中準確率也有限。如何在web端使用js實現人臉偵測呢?為了實現Web端人臉識別,需要熟悉相關的程式語言和技術,如JavaScript、HTML、CSS、WebRTC等。同時也需要掌握相關的電腦視覺和人工智慧技術。值得注意的是,由於Web端的計

模板化的優點和缺點有哪些? 模板化的優點和缺點有哪些? May 08, 2024 pm 03:51 PM

模板化:優點與缺點模板化是一種強大的程式設計技術,可讓您建立可重複使用的程式碼區塊。它提供了一系列優點,但也存在一些缺點。優點:程式碼重用性:模板化可讓您建立通用程式碼,可在整個應用程式中重複使用,從而減少重複和維護工作。一致性:模板化確保程式碼段在不同位置以相同的方式實現,從而提高程式碼一致性和可讀性。可維護性:對範本的變更會同時反映在所有使用它的程式碼中,簡化了維護和更新流程。效率:模板化可以節省時間和精力,因為您不必重複編寫相同的程式碼。靈活性:模板化可讓您建立可設定的程式碼區塊,可輕鬆適應不同的應用程式需求。缺點

選購系統前必看:Win11和Win10優缺點分析 選購系統前必看:Win11和Win10優缺點分析 Mar 28, 2024 pm 01:33 PM

在當今資訊時代,個人電腦作為我們日常生活中不可或缺的工具,扮演著重要的角色。作業系統作為電腦的核心軟體之一,更是影響我們的使用體驗以及工作效率。在市場上,微軟公司的Windows作業系統一直佔據主導地位,而現在人們面臨的選擇則是最新的Windows11和舊有的Windows10。對於一般消費者來說,在選擇作業系統時不只是看版本號,更要了解其優缺點。

Java Servlet的工作原理有什麼優缺點? Java Servlet的工作原理有什麼優缺點? Apr 16, 2024 pm 03:18 PM

JavaServlet是一種Java類,用於建立動態網頁,作為客戶端和伺服器的橋樑。工作原理:接收請求、初始化Servlet、處理請求、產生回應和關閉Servlet。優點:可移植、可擴展、安全且易於使用。缺點:開銷、耦合和狀態管理。實戰案例:建立一個簡單的Servlet來顯示"Hello,Servlet!"訊息。

PHP框架的優缺點比較:選哪個好? PHP框架的優缺點比較:選哪個好? Jun 04, 2024 pm 03:36 PM

PHP框架的選擇取決於專案需求和開發者技能:Laravel:功能豐富,社群活躍,但學習曲線陡峭,效能開銷高。 CodeIgniter:輕量級,易於擴展,但功能有限,文件較少。 Symfony:模組化,社群強大,但複雜,效能問題。 ZendFramework:企業級,穩定可靠,但笨重,許可昂貴。 Slim:微框架,速度快,但功能有限,學習曲線陡峭。

Golang編譯器彙總:探究各類編譯器優缺點 Golang編譯器彙總:探究各類編譯器優缺點 Jan 19, 2024 am 10:44 AM

隨著Golang的發展,越來越多的編譯器被開發出來。在選擇一款編譯器時,開發人員需要考慮許多因素,例如可靠性、效能、易用性等。本篇文章將彙整一些常見的Golang編譯器,並探討它們的優缺點,幫助開發者更好地選擇適合自己的編譯器。 Go官方編譯器Go官方編譯器是Golang的預設編譯器,也是Golang社群中廣受認可的編譯器。它具有以下優點:穩定性好體積小編譯

PHP與JS開發技巧:掌握繪製股票蠟燭圖的方法 PHP與JS開發技巧:掌握繪製股票蠟燭圖的方法 Dec 18, 2023 pm 03:39 PM

隨著網路金融的快速發展,股票投資已經成為了越來越多人的選擇。而在股票交易中,蠟燭圖是常用的技術分析方法,它能夠顯示股票價格的變動趨勢,幫助投資人做出更精準的決策。本文將透過介紹PHP和JS的開發技巧,帶領讀者了解如何繪製股票蠟燭圖,並提供具體的程式碼範例。一、了解股票蠟燭圖在介紹如何繪製股票蠟燭圖之前,我們首先需要先了解什麼是蠟燭圖。蠟燭圖是由日本人

C語言與Python:適用情境及優缺點分析 C語言與Python:適用情境及優缺點分析 Mar 22, 2024 am 11:24 AM

C語言與Python:適用情境及優缺點分析在電腦程式設計領域,C語言與Python是兩種非常流行的程式語言,它們各自有著獨特的優點和劣勢,適用於不同的場景。本文將對C語言與Python進行深入分析,探討它們的適用情境以及優缺點。一、C語言適用場景:C語言是一種以過程為導向的程式語言,具有高效性和優秀的效能,適合開發需要高度控制和效率的系統軟體、驅動程式和嵌入式系統

See all articles