0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

淺談Javascript數(shù)據(jù)類型

CHANBAEK ? 來源:myfreax ? 作者:myfreax ? 2022-12-09 16:43 ? 次閱讀

avaScript原始數(shù)據(jù)類型包括有objectnull,undefinedboolean,number,string

symbol從ES2015開始可用,bigint從ES2020開始可用。其中object是一個復(fù)雜的數(shù)據(jù)類型。

JavaScript是一種動態(tài)類型語言。這意味著變量不與類型相關(guān)聯(lián)。換句話說,一個變量可以保存不同類型的值。

例如在下面的type.js文件中,counter變量初始化的值是120,之后被賦值為布爾值false ,然后又被賦值為字符串foo

let counter = 120; // counter is a number
counter = false;   // counter is now a boolean
counter = "foo";   // counter is now a string

如果你需要知道當(dāng)前變量存儲的值類型,可以使用javascript的typeof運(yùn)算符,獲得變量的數(shù)據(jù)類型。

let counter = 120;
console.log(typeof(counter)); // "number"


counter = false; 
console.log(typeof(counter)); // "boolean"


counter = "Hi";
console.log(typeof(counter)); // "string"

undefined 未定義

undefined類型是只有一個原始類型的值undefined。默認(rèn)情況下,當(dāng)一個變量被聲明但未初始化時,它被賦值為undefined。

在下面的示例中,我們在第一行聲明一個變量counter。由于counter尚未初始化,因此為其分配的值是undefined。counter的類型也是undefined

值得注意的是,當(dāng)您使用尚未聲明的變量時,typeof運(yùn)算符也會返回undefined


let counter;
console.log(counter);        // undefined
console.log(typeof counter); // undefined

null 空類型

null類型是第二種原始數(shù)據(jù)類型,也只有一個值null。

當(dāng)你在瀏覽器的控制臺運(yùn)行代碼typeof null時,代碼將會返回一個對象。這是一個在Javascript的bug。

雖然有人曾經(jīng)提出過修復(fù)此錯誤,但被拒絕。原因是修復(fù)此Bug會破壞許多現(xiàn)有站點(diǎn)。

在JavaScript數(shù)據(jù)類型null是等于undefined的,因為在Javascript的null值是等于布爾值false,undefined也是如此。


let obj = null;
console.log(typeof obj); // object
console.log(null == undefined); // true

number 數(shù)值類型

JavaScript使用用number類型來表示整數(shù)和浮點(diǎn)數(shù)。下面的語句聲明一個變量并用一個整數(shù)初始化它的值。要表示浮點(diǎn)數(shù),請包含一個小數(shù)點(diǎn),后跟至少一個數(shù)字。

如果數(shù)字看起來是整數(shù),例如代碼let price = 200.00;,JavaScript會自動將浮點(diǎn)數(shù)轉(zhuǎn)換為整數(shù)。

原因是Javascript總是希望使用更少的內(nèi)存,因為浮點(diǎn)值使用的內(nèi)存是整數(shù)值的兩倍。

如果要獲取數(shù)值類型的范圍,可以打開瀏覽器控制臺運(yùn)行代碼Number.MIN_VALUE獲取最小值和運(yùn)行代碼Number.MAX_VALUE獲取最大值。


let num = 100;
let price= 12.5;
let discount = 0.05;

NaN 非數(shù)值類型

NaN代表非數(shù)值。它是一個特殊的數(shù)值,表示一個無效的數(shù)字。當(dāng)強(qiáng)制轉(zhuǎn)換字符串為值時,它會返回NaN。

NaN有兩個特點(diǎn)。第一特點(diǎn)是所有與NaN的運(yùn)算都會返回NaN ,例如代碼console.log(NaN/2);

第二個特點(diǎn)是NaN不等于任何值,包括它自己本省,例如代碼console.log(NaN == NaN);。

console.log('a'/2); // NaN;
console.log(NaN/2); // NaN
console.log(NaN == NaN); // false

string 字符串類型

在JavaScript,字符串是零個或多個字符的序列。字符串文字以單引號 '或雙引號 " 開始和結(jié)束。

以雙引號開頭的字符串必須以雙引號結(jié)尾。同樣,以單引號開頭的字符串也必須以單引號結(jié)尾。

如果要在字符串中使用單引號或雙引號,則需要使用反斜杠對其進(jìn)行轉(zhuǎn)義。例如代碼let message = 'I\\'m also a valid string';

JavaScript字符串是不可變的。這意味著它一旦創(chuàng)建就無法修改。但是,您可以從現(xiàn)有字符串創(chuàng)建新字符串。

string.js例子中首先,聲明str變量并將其初始化為'JavaScript'。其次,使用加號運(yùn)算符組合'JavaScript'' String',使其值成功為'Javascript String'

在幕后,JavaScript引擎創(chuàng)建一個新字符串來保存'JavaScript String'并銷毀原始字符串'JavaScript''String'。

let str = 'JavaScript';
str = str + ' String';

boolean 布爾類型

布爾值類型有兩個字面值,分別是truefalse。下面的示例聲明了兩個保存布爾值的變量。

JavaScript允許將其他類型的值轉(zhuǎn)換為布爾值的truefalse。要將另一種數(shù)據(jù)類型的值轉(zhuǎn)換為布爾值,請使用Boolean()函數(shù)。

確切的說Boolean()不是函數(shù),它是一個對象,用于創(chuàng)建布爾值,Boolean接受一個參數(shù),并將指定的參數(shù)轉(zhuǎn)換為布爾值。


let inProgress = true;
let completed = false;


console.log(typeof completed); // boolean
console.log(Boolean('Hi'));// true
console.log(Boolean(''));  // false


console.log(Boolean(20));  // true
console.log(Boolean(Infinity));  // true
console.log(Boolean(0));  // false


console.log(Boolean({foo: 100}));  // true on non-empty object
console.log(Boolean(null));// false

symbol 符號類型

JavaScript在ES6中添加了一個原始類型符號symbol。與其他原始類型不同,symbol符號類型沒有文字形式。

要創(chuàng)建符號,請調(diào)用函數(shù)Symbol,每次調(diào)用符號函數(shù)都會創(chuàng)建一個新的唯一值。

symbol值可以作為對象屬性的標(biāo)識符,通常使用它來創(chuàng)建對象的私有屬性與方法數(shù)據(jù)類型僅有的目的。


let s1 = Symbol();
console.log(Symbol() == Symbol()); // false

bigint 類型

**BigInt 是一種內(nèi)置對象,它提供了一種方法來表示大于2 ^53^ –1的整數(shù)。這原本是 Javascript中可以用Number表示的最大數(shù)字。 BigInt**可以表示任意大的整數(shù)。

它在某些方面類似于Number,但是也有幾個不同點(diǎn),不能用于Math對象中的方法。

不能和任何Number實例混合運(yùn)算,兩者必須轉(zhuǎn)換成同一種類型。在兩種類型來回轉(zhuǎn)換時要小心,因為BigInt變量在轉(zhuǎn)換成Number變量時可能會丟失精度。

要創(chuàng)建bigint數(shù)字可以在一個整數(shù)的后面加追加字母n ,例如10n,或者調(diào)用函數(shù) BigInt()并傳遞一個整數(shù)值或著是字符串的數(shù)字。

如果傳遞的是字符串的數(shù)字, BigInt() 將會強(qiáng)制轉(zhuǎn)換字符串類型為數(shù)值。


const theBiggestInt = 9007199254740991n;


const alsoHuge = BigInt(9007199254740991);

object 對象類型

在JavaScript,對象是屬性的集合,每個屬性都定義為鍵值對。對象的屬性名稱可以是任何字符串或者符號symbol的值。

如果屬性名稱不是有效標(biāo)識符,您可以在屬性名稱周圍使用引號。例如,如果對象的屬性名稱是full-name,則必須將其放在引號中。

對象的屬性不僅可以保存簡單值,也可以保存復(fù)雜的數(shù)據(jù)類型對象。


let contact = {
    firstName: 'web',
    lastName: 'myfreax',
    'full-name':'web@myfreax'
    email: 'web@myfreax.com',
    phone: '408555-9999',
    address: {
        building: '4000',
        street: 'North 1st street',
        city: 'San Jose',
        state: 'CA',
        country: 'USA'
    }
}

要訪問對象的屬性,您可以使用點(diǎn)符號. 或者類似數(shù)組的符號[]。當(dāng)要訪問屬性嵌套的對象時,也可以繼續(xù)使用點(diǎn)符號.訪問嵌套的屬性。

如果你訪問一個不存在的屬性,你會得到一個未定義的值。

console.log(contact.firstName);
console.log(contact.lastName);
console.log(contact.age); // undefined
console.log(contact['phone']); // '(408)-555-9999'
console.log(contact['email']); // 'web@myfreax'
console.log(contact['address']['building']); // '4000'
console.log(contact.address.building); // '4000'

結(jié)論

JavaScript的基本類型是number、string、boolean、null、undefinedsymbol以及bigint和復(fù)雜類型對象object。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • javascript
    +關(guān)注

    關(guān)注

    0

    文章

    516

    瀏覽量

    53865
  • 數(shù)據(jù)類型
    +關(guān)注

    關(guān)注

    0

    文章

    236

    瀏覽量

    13624
  • undefined
    +關(guān)注

    關(guān)注

    0

    文章

    11

    瀏覽量

    2780
收藏 人收藏

    評論

    相關(guān)推薦

    JavaScript 【1】 基礎(chǔ)數(shù)據(jù)類型

    。推薦閱讀:https://www.runoob.com/js/js-tutorial.html這里我們重點(diǎn)介紹JavaScript的9個知識點(diǎn)。key- val二、數(shù)據(jù)類型:值類型(基本類型
    發(fā)表于 07-17 10:32

    vhdl數(shù)據(jù)類型

    VHDL中的標(biāo)識符可以是常數(shù)、變量、信號、端口、子程序或參數(shù)的名字。VHDL中的數(shù)據(jù)類型可以分成四大類: 標(biāo)量型(SCALAR TYPE):屬單元素的最基本的數(shù)據(jù)類型,通常用于描述一個單值數(shù)據(jù)對象
    發(fā)表于 03-30 15:59 ?11次下載

    Struct結(jié)構(gòu)數(shù)據(jù)類型

    Struct類型是一種由多個不同數(shù)據(jù)類型元素組成的數(shù)據(jù)結(jié)構(gòu),其元素可以是基本數(shù)據(jù)類型,也可以是Struct、數(shù)組等復(fù)雜數(shù)據(jù)類型以及PLC
    的頭像 發(fā)表于 07-25 17:02 ?3019次閱讀

    結(jié)構(gòu)數(shù)據(jù)類型(Struct)及應(yīng)用案例

    Struct數(shù)據(jù)類型使用非常靈活,隨時可以使用,但是相對于PLC數(shù)據(jù)類型 (UDT) 有以下缺點(diǎn),所以建議需要使用Struct類型時,可以使用PLC數(shù)據(jù)類型(UDT)代替。
    的頭像 發(fā)表于 07-27 16:10 ?1818次閱讀

    什么是數(shù)據(jù)類型轉(zhuǎn)換

    常用的3種數(shù)據(jù)類型:1、Python數(shù)據(jù)類型第一種:字符串(str)。 2、Python數(shù)據(jù)類型第二種:整數(shù)(int)。 3、Python數(shù)據(jù)類型第三種:浮點(diǎn)數(shù)(float)。
    的頭像 發(fā)表于 02-23 15:21 ?1780次閱讀

    定義數(shù)據(jù)類型

    在運(yùn)算之前我們必須首先定義出數(shù)據(jù)類型,定義出腳本支持的數(shù)據(jù)類型,這是運(yùn)算的基礎(chǔ)。 這一小節(jié)我們將定義出數(shù)據(jù)類型,在這里我們暫時定義四個數(shù)據(jù)類型:
    的頭像 發(fā)表于 03-03 10:10 ?953次閱讀

    PLC數(shù)據(jù)類型

    基本數(shù)據(jù)類型 ? ? ? 基本數(shù)據(jù)類型? ? 包括位、位序列、整數(shù)、浮點(diǎn)數(shù)、日期時間。(常見的) 1、位 字節(jié) 字 雙字 2、數(shù)據(jù)類型 3 浮點(diǎn)數(shù) 實(或浮點(diǎn))數(shù)以 32 位單精度數(shù) (Real
    發(fā)表于 04-17 15:49 ?0次下載
    PLC<b class='flag-5'>數(shù)據(jù)類型</b>

    ARRAY 數(shù)據(jù)類型的變量

    要求 全局數(shù)據(jù)塊已打開。 操作步驟 要聲明一個 ARRAY 數(shù)據(jù)類型的變量,請按以下步驟操作: 在“名稱”(Name) 列中,輸入變量的名稱。 在“數(shù)據(jù)類型”列中輸入“Array”數(shù)據(jù)類型
    的頭像 發(fā)表于 07-06 11:08 ?1112次閱讀

    淺談PLC定義數(shù)據(jù)類型的應(yīng)用

    PLC定義數(shù)據(jù)類型以下用一個例子介紹PLC定義數(shù)據(jù)類型的應(yīng)用,以便進(jìn)一步理解PLC定義數(shù)據(jù)類型。
    的頭像 發(fā)表于 07-24 16:07 ?1333次閱讀
    <b class='flag-5'>淺談</b>PLC定義<b class='flag-5'>數(shù)據(jù)類型</b>的應(yīng)用

    F型PLC數(shù)據(jù)類型與標(biāo)準(zhǔn)PLC數(shù)據(jù)類型(UDT)之間的差別在哪?

    可以像使用標(biāo)準(zhǔn) PLC 數(shù)據(jù)類型 (UDT) 那樣,聲明和使用 F 型 PLC 數(shù)據(jù)類型 (UDT) ??梢栽诎踩绦蛑幸约皹?biāo)準(zhǔn)用戶程序中使用 F 型 PLC 數(shù)據(jù)類型 (UDT) 。
    的頭像 發(fā)表于 08-27 09:54 ?1153次閱讀
    F型PLC<b class='flag-5'>數(shù)據(jù)類型</b>與標(biāo)準(zhǔn)PLC<b class='flag-5'>數(shù)據(jù)類型</b>(UDT)之間的差別在哪?

    Redis的數(shù)據(jù)類型有哪些

    Redis的數(shù)據(jù)類型有哪些?有五種常用數(shù)據(jù)類型:String、Hash、Set、List、SortedSet。以及三種特殊的數(shù)據(jù)類型:Bitmap、HyperLogLog、Geospatial
    的頭像 發(fā)表于 10-09 10:51 ?807次閱讀

    javascript的基本數(shù)據(jù)類型有哪些

    JavaScript 是一種動態(tài)的、面向?qū)ο蟮木幊陶Z言,廣泛應(yīng)用于 Web 開發(fā)中。在 JavaScript 中,有七種基本數(shù)據(jù)類型(Primitive Types),它們分別是 Undefined
    的頭像 發(fā)表于 12-03 11:17 ?759次閱讀

    javascript的typeof返回哪些數(shù)據(jù)類型?

    JavaScript的typeof操作符用于確定一個值的數(shù)據(jù)類型,可能的返回值包括以下幾種: "undefined":當(dāng)一個變量被聲明但未被賦值時,其類型為undefined。 "boolean
    的頭像 發(fā)表于 12-03 11:41 ?798次閱讀

    oracle的數(shù)據(jù)類型有哪些

    Oracle數(shù)據(jù)庫中有許多數(shù)據(jù)類型可供選擇,每種數(shù)據(jù)類型都有其各自的特點(diǎn)和適用場景。下面是對Oracle數(shù)據(jù)庫中最常用的數(shù)據(jù)類型的詳盡說明,
    的頭像 發(fā)表于 12-05 16:45 ?2428次閱讀

    plc數(shù)據(jù)類型怎么理解和應(yīng)用

    PLC(可編程邏輯控制器)是一種工業(yè)自動化設(shè)備,用于控制機(jī)械和工業(yè)過程。在PLC編程中,數(shù)據(jù)類型是非常重要的概念,因為它決定了程序中數(shù)據(jù)的存儲和處理方式。正確理解和應(yīng)用PLC數(shù)據(jù)類型是編寫有效、可靠
    的頭像 發(fā)表于 12-19 11:39 ?4266次閱讀