国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

JavaScript聲明變量詳解

paulquei / 1732人閱讀

摘要:命令用于規定模塊的對外接口,命令用于輸入其他模塊提供的功能所以在一定程度上來說,也具有聲明變量的功能。當沒有聲明,直接給變量賦值時,會隱式地給變量聲明,此時這個變量作為全局變量存在。

前言

如果文章中有出現紕漏、錯誤之處,還請看到的小伙伴多多指教,先行謝過

ES5階段,JavaScript 使用 varfunction 來聲明變量, ES6 中又添加了letconstimportClass 這幾種聲明變量的方式。那么,他們各自都有什么樣的特點呢?

下面,就讓我們一起去探究一下吧

以下↓

變量就是存儲信息的容器。 ECMAScript 的變量是松散類型的,所謂松散類型就是可以用來保存任何類型的數據
var 聲明

一直以來,我們都是使用var關鍵字來聲明變量

var a = 1;
var b;

console.log(a) // 1
console.log(b) // undefined
console.log(c) // undefined

var b = 2;
var c = 3;
console.log(b) // 2
console.log(c) // 3

function f() {
    var c = 4;
    console.log(c) // 4
    c = 5;
    console.log(c) // 5
}
f();
console.log(c) // 3

function fun() {
    c = 6
}
fun();
console.log(c) // 6

從上面的結果我們不難看出,使用var聲明的變量具有以下特點:

變量可以沒有初始值,會保存一個特殊的值 undefined

變量可以重復定義,且可以修改值

變量聲明語句從自動提升到所在作用域的頂端

函數內重復定義對函數外無影響(局部變量)

函數內重新賦值對函數外有影響

function 關鍵字聲明

在ES5中,除了使用var聲明變量,我們也可以使用 function 關鍵字聲明變量

f();
function f() {console.log(1)}
var f;

console.log(f) // function f

特點:

使用 function 聲明的是函數對象,也存在聲明提升

函數聲明要優于變量聲明

let聲明

由于 ES5 中使用 var 聲明變量存在著一些很讓人迷惑的特性(比如變量提升,重復定義等),ES6 中新增 let 命令,用來聲明變量。它的用法類似于 var ,但是所聲明的變量,只在 let 命令所在的代碼塊內有效

{
    var a = 1;
    let b = 2;
}
console.log(a) // 1
console.log(b) // Uncaught ReferenceError: b is not defined

console.log(c) // Uncaught ReferenceError: c is not defined

let c = 3

let a = 4

console.log(a) // Identifier "a" has already been declared

通過以上的代碼,我們很容易發現使用 let 聲明變量的特點:

let聲明的變量只在它所在的代碼塊有效

不存在變量提升

不可以重復聲明

由于 let 聲明變量的這些特點,所以 for 循環的計數器,就很合適使用 let 命令

for(let i = 0; i < 10; i++) {
    //
}

console.log(i) // Uncaught ReferenceError: c is not defined

// 如果使用var聲明,則在這里輸出的就是10
let 實際上為 JavaScript 新增了塊級作用域
const聲明

const 也是 ES6 新增的聲明變量的方式,const 聲明一個只讀的常量。一旦聲明,常量的值就不能改變

const API;

console.log(API) // SyntaxError: Missing initializer in const declaration

console.log(MAX); // Uncaught ReferenceError: MAX is not defined
const MAX = 1;

const MAX = 2;

console.log(MAX); // Identifier "MAX" has already been declared

const PI = 3.1415;

console.log(PI) // 3.1415

PI = 3; // TypeError: Assignment to constant variable.

const f = {}
f.name = "HELLO" // 正常執行

f = {name: "World"} // 報錯

所以,使用 const 聲明的變量具有以下特點:

const 一旦聲明變量,就必須立即初始化,不能留到以后賦值

不允許重復聲明

不存在變量提升

const 實際上保證的,并不是變量的值不得改動,而是變量指向的那個內存地址不得改動

如果真的想將對象凍結,應該使用 Object.freeze 方法
import 聲明

ES6 新增的模塊的概念。

模塊功能主要由兩個命令構成:exportimportexport 命令用于規定模塊的對外接口,import 命令用于輸入其他模塊提供的功能

所以在一定程度上來說,import 也具有聲明變量的功能。只是在使用 import 的時候,具有一些限制

export { first, last } 

import { first, last } from "./xxx"

first = {} // Syntax Error : "a" is read-only;

first.name = "Hello" // 成功執行,但是不建議這樣使用

export default function(){} // a.js

import xxx from "a.js"

import { New as $ } from "./xxx"

特點:

import 命令接受一對大括號,大括號里面的變量名,必須與被導入模塊對外接口的名稱相同

import 命令輸入的變量都是只讀的,因為它的本質是輸入接口

當使用 export default 命令,為模塊指定默認輸出的時候,import 命令可以為該匿名函數指定任意名字

import 命令具有提升效果,會提升到整個模塊的頭部,首先執行

如果想為輸入的變量重新取一個名字,import 命令要使用 as 關鍵字,將輸入的變量重命名

本質上,export default 就是輸出一個叫做 default 的變量或方法,然后系統允許你為它取任意名字
class 聲明

ES6 引入了類的概念,有了 class 這個關鍵字,作為對象的模板。通過 class 關鍵字,可以定義類

class Point {
  constructor(x, y) {
    this.x = x;
    this.y = y;
  }

  toString() {
    return "(" + this.x + ", " + this.y + ")";
  }
}
ES6class 可以看作只是一個語法糖,它的絕大部分功能,ES5 都可以做到,類的實質還是函數對象,類中的方法和對象其實都是掛在對應的函數對象的 prototype 屬性下

所以就可以改寫成下面這種ES5的方式

function Point(x, y) {
    this.x = x;
    this.y = y;
}

Point.prototype.toString = function() {
    return "(" + this.x + ", " + this.y + ")";
}

特點:

所有類都有 constructor 函數,如果沒有顯式定義,一個空的 constructor 方法會被默認添加。當然所有函數對象都必須有個主體

生成類的實例對象的寫法,與 ES5 通過構造函數生成對象完全一樣,也是使用 new 命令

class B {}

let b = new B();

在類的實例上面調用方法,其實就是調用原型上的方法

與函數對象一樣,Class 也可以使用表達式的形式定義

Class 其實就是一個 function ,但是有一點不同,Class 不存在變量提升,也就是說 Class 聲明定義必須在使用之前

全局變量
在瀏覽器環境指的是 window 對象,在 Node 指的是 global 對象。ES5 之中,頂層對象的屬性與全局變量是等價的

var 命令和 function 命令聲明的全局變量,依舊是頂層對象的屬性;另一方面規定,let 命令、const 命令、class 命令聲明的全局變量,不屬于頂層對象的屬性。也就是說,從 ES6 開始,全局變量將逐步與頂層對象的屬性脫鉤

var a = 1;

window.a // 1

let b = 2;

window.b // undefined
隱式聲明

JavaScript 中還存在著隱式聲明。

a = 1;
console.log(a) // 1
當沒有聲明,直接給變量賦值時,會隱式地給變量聲明,此時這個變量作為全局變量存在。這個時候就不存在聲明提前的問題了
最后

其實只要我們理解并掌握了這幾種聲明變量的方式,記住它們的特點,那么在實際使用的過程當中就很容易能夠找到最合適的方式去定義

每天學習分享,不定期更新

最后,推薦一波前端學習歷程,這段時間總結的一些面試相關,分享給有需要的小伙伴,歡迎 star 關注 傳送門

參考文檔

ECMAScript 6入門

ES6變量聲明

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/109258.html

相關文章

  • Javascript變量作用域詳解

    摘要:變量作用域詳解作用域規則大部分情況下沒有塊級作用域除非你使用當你使用的情況下僅僅支持函數作用域不使用聲明的變量為全局變量不用情況下中局部變量只能通過和函數參數聲明大部分情況下沒有塊級作用域除非你使用與很多語言不同在之前并沒有塊級作用域一個作 Javascript變量作用域詳解 JS作用域規則 JS大部分情況下沒有塊級作用域, 除非你使用let 當你使用var的情況下, JS僅僅支持函...

    Miracle 評論0 收藏0
  • javascript 聲明變量var、let、const詳解及示例

    摘要:概述發布前,只能通過聲明變量的方式,常量塊級變量函數變量這些概念的差別都不能很好的體現出來,于此同時,加入你要使用或者提供一個,聲明的變量可隨時被修改和重新分配的問題,會讓你時刻擔心代碼是否能正常運行。 1. var、let、const概述 ES6發布前,Javascript只能通過var聲明變量的方式,常量、塊級變量、函數變量這些概念的差別都不能很好的體現出來,于此同時,加入你要使用...

    tuomao 評論0 收藏0
  • ES6 變量作用域與提升:變量的生命周期詳解

    摘要:不同的是函數體并不會再被提升至函數作用域頭部,而僅會被提升到塊級作用域頭部避免全局變量在計算機編程中,全局變量指的是在所有作用域中都能訪問的變量。 ES6 變量作用域與提升:變量的生命周期詳解從屬于筆者的現代 JavaScript 開發:語法基礎與實踐技巧系列文章。本文詳細討論了 JavaScript 中作用域、執行上下文、不同作用域下變量提升與函數提升的表現、頂層對象以及如何避免創建...

    lmxdawn 評論0 收藏0
  • 淺談JavaScript代碼預解析 + 示例詳解

    摘要:知識點聲明的變量在預解析的時候只執行聲明,不會執行定義,默認值是。聲明的函數在預解析的時候會提前聲明并且會同時定義。 showImg(https://segmentfault.com/img/bVbnY76?w=2500&h=1250); 知識點 var 聲明的變量在預解析的時候只執行聲明,不會執行定義,默認值是 undefined。 function 聲明的函數在預解析的時候會...

    sunnyxd 評論0 收藏0
  • 詳解js變量聲明提升

    摘要:換句話說,在代碼執行之前,會對作用域鏈中所有變量和函數聲明先處理完先。總結一句話就是只有聲明被提升,而賦值或其他運算會留在原地。為其聲明變量隱性劫持到所在區域中。 之前一直覺會認為javascript代碼執行是由上到下一行行執行的。自從看了《你不知道的JS》后發現這個觀點并不完全正確。先來給大家舉一個書本上的的例子: var a=hello world; var a; co...

    NSFish 評論0 收藏0

發表評論

0條評論

paulquei

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<