5 JavaScript變數提升

来源:https://www.cnblogs.com/zczhaod/archive/2023/08/21/17639686.html
-Advertisement-
Play Games

##### 5 變數提升 看以下代碼, 或多或少會有些問題的. ```javascript function fn(){ console.log(name); var name = '大馬猴'; } fn() ``` 發現問題了麽. 這麼寫代碼, 在其他語言里. 絕對是不允許的. 但是在js里. 不 ...


5 變數提升

看以下代碼, 或多或少會有些問題的.

function fn(){
    console.log(name);
    var name = '大馬猴';
}
fn()

發現問題了麽. 這麼寫代碼, 在其他語言里. 絕對是不允許的. 但是在js里. 不但允許, 還能執行. 為什麼呢? 因為在js執行的時候. 它會首先檢測你的代碼. 發現在代碼中會有name使用. OK. 運行時就會變成這樣的邏輯:

function fn(){
    var name;
    console.log(name);
    name = '大馬猴';
}
fn()

看到了麽. 實際運行的時候和我們寫代碼的順序可能會不一樣....這種把變數提前到代碼塊第一部分運行的邏輯被稱為變數提升. 這在其他語言里是絕對沒有的. 並且也不是什麼好事情. 正常的邏輯不應該是這樣的. 那麼怎麼辦? 在新的ES6中. 就明確了, 這樣使用變數是不完善的. es6提出. 用let來聲明變數. 就不會出現該問題了.

function fn(){
    console.log(name);  // 直接報錯, let變數不可以變數提升.
    let name = '大馬猴'; 
}
fn()

結論一, 用let聲明變數是新版本javascript提倡的一種聲明變數的方案.
let還有哪些作用呢?

function fn(){
    // console.log(name);  // 直接報錯, let變數不可以變數提升.
    // let name = '大馬猴';
    var name = "JAY";
    var name = "WLH" 
	/*註意, 報錯是發生在代碼檢查階段. 所以. 上述代碼根本就執行不了. 
==結論二, 在同一個作用域內. let聲明的變數只能聲明一次. 其他使用上和var沒有差別=="; */
    console.log(name);
}
fn()

顯然一個變數被聲明瞭兩次. 這樣也是不合理的. var本意是聲明變數. 同一個東西. 被聲明兩次. 所以ES6規定. let聲明的變數. 在同一個作用域內. 只能聲明一次.

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>變數提升</title>
</head>
<body>

    <script src = "變數提升.js"></script>

</body>
</html>
// // 變數提升
// function fn() {
//     console.log(name);
//     var name = '大馬猴';
// }
// fn();
//
// function fn() {
//     var name;
//     console.log(name);
//     name = '大馬猴';
// }
// fn();

// // let 聲明變數可以避免變數提升問題
// function gn() {
//     console.log(name);  // 直接報錯, let變數不可以變數提升.
//     let name = '大馬猴';
// }
// gn();


// function sn() {
//     var name = 'jay';
//     var name = 'wlh';
//     console.log(name);
// }   // 一個變數被聲明瞭兩次. 這樣也是不合理的
// sn();   // wlh

// // 在同一個作用域內. let聲明的變數只能聲明一次. 其他使用上和var沒有差別
// function xn() {
//     let name = 'jay';
//     console.log(name);
//     let name = 'wlh';
//     console.log(name);
// }
// xn();   // 報錯是發生在代碼檢查階段. 所以. 上述代碼根本就執行不了

本文來自博客園,作者:生而自由愛而無畏,轉載請註明原文鏈接:https://www.cnblogs.com/zczhaod/p/17639686.html


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

-Advertisement-
Play Games
更多相關文章
  • # 前言 本篇來介紹一下redis pipeline,主要是由於最近一次在幫開發同學review代碼的時候,發現對redis有個迴圈操作可以優化。場景大概是這樣的,根據某個uid要從redis查詢一批數據,每次大概1000個key左右,如果查得到就返回,否則查db,然後寫回緩存。由於每次要查的key ...
  • 鎖共有多種演算法,在併發場景中都是被常常用到,想必大家都已爐火純青般.....巴特!我們還有後浪同學們可能不熟悉,那我在這裡聊下鎖的用法和使用場景。 ...
  • - 1.說在前面的話 - 2.安裝employees測試庫 - 3.觀測SQL運行狀態 - - 3.1 觀測SQL運行時的記憶體消耗 - 3.2 觀測SQL運行時的其他開銷 - 3.3 觀測SQL運行進度 > 感知SQL運行時的狀態 ## 1. 說在前面的話 在MySQL里,一條SQL運行時產生多少磁 ...
  • 簡述 上篇文章介紹瞭如何搭建 prometheus 監控體系,監控 linux 伺服器,這篇文章跟大家介紹如何監控 redis,以及我們要關註的指標都有哪些 監控 redis 需要關註什麼指標 在《聊聊監控》這篇文章,介紹了 google 提出的監控四個黃金指標(沒看過的朋友可以看看這篇文章),下麵 ...
  • 轉載請標明出處:https://www.cnblogs.com/tangZH/p/17307406.html - [kotlin協程小記](http://77blogs.com/?p=73 "kotlin協程小記") - [協程的async使用](http://77blogs.com/?p=77 " ...
  • - [kotlin協程小記](http://77blogs.com/?p=73 "kotlin協程小記") - [協程的async使用](http://77blogs.com/?p=77 "協程的async使用") - [kotlin協程異常處理之-try catch ](http://77blog ...
  • ##### CSS 背景屬性 ##### 1. background-color(背景顏色) 頁面的背景顏色有四種屬性值表示,分別是transparent(透明),RGB十進位顏色表示,十六進位顏色表示和顏色單詞表示。 屬性使用: ``` /* background-color: transpare ...
  • ##### 8 文本屬性 font-style(字體樣式風格) ``` /* 屬性值: normal:設置字體樣式為正體。預設值。 italic:設置字體樣式為斜體。這是選擇字體庫中的斜體字。 oblique:設置字體樣式為斜體。人為的使文字傾斜,而不是去使用字體庫的斜體字。 */ ``` font ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...