語言基礎---變數

来源:https://www.cnblogs.com/littlecookie/archive/2022/09/30/16745569.html
-Advertisement-
Play Games

語言基礎-變數 前言 從本篇博客開始 博主個人認為重要的知識點都會在在行前添加 ⭐ 來進行標識 變數 ECMASCRIPT變數是鬆散類型,意思是變數可以用於保存任何類型的數據。ECMASCRIPT中有三個關鍵字可以來聲明變數:var、let和const。 值得註意的是let和const只能在ES6以 ...


語言基礎-變數

前言

從本篇博客開始 博主個人認為重要的知識點都會在在行前添加 ⭐ 來進行標識

變數

ECMASCRIPT變數是鬆散類型,意思是變數可以用於保存任何類型的數據。ECMASCRIPT中有三個關鍵字可以來聲明變數:var、let和const。

值得註意的是let和const只能在ES6以及更晚的版本中使用。

var關鍵字

定義變數的基本方式:

var message;//個人不推薦,在不初始化的情況下定義變數,就會保存一個特殊的值undefinded。

var car="賓士";//ECMASCRIPT 實現變數初始化,此時就可以定義變數並設置它的初始值。

car=100;//合法,但是不推薦。

上面對於car變數的操作中,有一點值得註意,car變數首先被定義為一個字元串變數,後來又被賦值為數值。雖然這在ECMASCRIPT中完全合法,但是想想當項目龐大起來,一個能被隨意賦值的變數會給項目增加多大的維護難度。這可能就是為啥現在TypeScript那麼被青睞的原因之一。

var的作用域

⭐var是函數作用域,也就是說在函數內定義變數 在會在函數內部生效,併在函數退出時銷毀該變數,這裡就會涉及到js的垃圾回收機制。後面寫到的再細說,示例代碼如下:

function myfun(){
	var message='hello';
	//message=hello'; 合法,但不推薦,這樣可以再局部作用域中定義全局變數。不推薦的原因也是因為不好維護,畢竟想想就很奇怪
}
myfun();
console.log(message);//報錯

var聲明提升

⭐使用var聲明變數會把變數自動提升到函數作用域頂部

function foo(){
	console.log(name);
	var name='Mercy';	
}
foo();//undefined

之所以不會報錯,是因為ECMASCRIPT把他等價於如下代碼:

function foo(){
	var name;
	console.log(name);
	name='Mercy';	
}
foo();//undefined

let關鍵字

let作用域

⭐let跟var的作用差不多,但是有著非常重要的區別。最明顯的區別就是,let聲明的範圍是塊作用域,而var聲明的範圍是函數作用域。啥是塊作用域通俗點講就是 花括弧 { } 包裹的代碼塊。

if(true){
   var name='Mercy';
   cosnole.log(name);//Mercy
}
cosnole.log(name);//Mercy
if(true){
   let name='Mercy';
   cosnole.log(name);//Mercy
}
cosnole.log(name);//ReferenceError:name 沒有定義

冗餘聲明

⭐let也不允許同一個塊作用域中出現冗餘聲明。

var name;
var name;

let age;
let age;//SyntaxError:標識符age已經聲明過了

暫時性死區

⭐let與var的另一個重要的區別就是let聲明的變數不會再作用域中被提升。

cosnole.log(age);
let age=22;//ReferenceError:age 沒有定義

在let聲明之前的執行瞬間被稱為“暫時性死區”,在此階段引用後面才聲明的變數都會拋出ReferenceError。

全局聲明

與var關鍵字不同,使用let在全局作用域中聲明的變數不會成為為window對象的屬性(var聲明的變數則會)。

var name = 'Matt'; 
console.log(window.name); // 'Matt' 
let age = 26; 
console.log(window.age); // undefined

---持續更新中---


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、原理總結 利用兩個寄存器R4和R5來存儲兩個數位管的顯示效果,R4是前一個數位管顯示所需,而R5是後一個數位管顯示所需,利用左移操作RLC來使之每一位被依次輸入到C中,然後將C輸入到LED中(當LED每位都有數據時,數位管才會顯示),利用停頓函數使數位管上數字停留一段時間。 二、程式分析 以下為 ...
  • Java資料庫的安裝和使用 1.資料庫的作用 一個問題:淘寶網、京東、微信抖音,都有各自的功能,那麼我們退出系統的時候,為什麼信息還在? 解決之道-文件,資料庫 為瞭解決上訴問題,使用更加利於管理數據東西-資料庫,他能更加有效地管理數據。 舉一個生活化的案例說明:如果說圖書館是保存書籍的,那麼資料庫 ...
  • LIKE操作符:通配符搜索只能用於文本欄位(字元串) 1、%通配符 1 select 2 col_name 3 from 4 table_name 5 where 6 col_name 7 like "%str" 2、_通配符 1 select 2 col_name 3 from 4 table_n ...
  • 一直使用Postgresql資料庫,有一張表是這樣的: DROP TABLE IF EXISTS "public"."devicedata"; CREATE TABLE "public"."devicedata" ( "Id" varchar(200) COLLATE "pg_catalog"."d ...
  • 據中國信通院發佈,2012年到2021年10年間,我國數字經濟規模由12萬億元增長到45.5萬億元,在整個GDP中的比重由21.6%提升至39.8%。順應時代發展新趨勢,“數據”成為新的生產要素已是毋庸置疑的共識。 如果說數據中台的崛起代表著企業數字化轉型從流程驅動走向數據驅動,從數字化走向智能化。 ...
  • 首發微信公眾號:SQL資料庫運維 原文鏈接:https://mp.weixin.qq.com/s?__biz=MzI1NTQyNzg3MQ==&mid=2247485212&idx=1&sn=450e9e94fa709b5eeff0de371c62072b&chksm=ea37536cdd40da7 ...
  • 現如今,手機錄屏是必不可少的能力之一。對於游戲領域作者來說,在平時直播玩游戲、製作攻略、操作集錦時,不方便切屏,這時在游戲內如果有一個錄製按鈕就可以隨時開啟,記錄下每個精彩瞬間,減少後期剪輯工作量;在直播App中開啟一鍵錄屏,不光方便主播後續的賬號運營與復盤,用戶也能隨時截取有意思的片段傳播在社交媒 ...
  • #背景 webpack構建過程中的hooks都有什麼呢?除了在網上看一些文章,還可以通過更直接的辦法,結合官方文檔快速讓你進入webpack的hook世界 寫一個入口文件 //index.js const webpack = require("webpack"); const path = requ ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...