摘要:中的數(shù)據(jù)類型變量包含兩種不同的數(shù)據(jù)類型的值基本類型值和引用類型值。對于引用類型返回均為使用檢測引用型數(shù)據(jù)類型時的最佳選擇是因?yàn)楦鶕?jù)規(guī)定,所用引用類型的值都是的實(shí)例,因此都是返回引用類型與基本包裝類型的主要區(qū)別就是對象的生存期。
javaScript中的數(shù)據(jù)類型
ECMAScript 變量包含兩種不同的數(shù)據(jù)類型的值:基本類型值和引用類型值 。 基本數(shù)據(jù)類型指的是簡單的數(shù)據(jù)段,而引用數(shù)據(jù)類型指那些可能有多個值組成的對
基本類型(值類型)Undefined 在使用var聲明變量但未對其初始化時,或者使用了一個并未聲明的變量時,又或者使用了一個并不存在的對象屬性時,這個變量的值就是undefined。
Null 從邏輯上看,null值表示一個空對象指針,獨(dú)一無二。
Boolean true、false
Number NaN,即非數(shù)值(Not a Number)是一個特殊的數(shù)值,這個數(shù)值用于表示一個本來要返回?cái)?shù)值的操作數(shù)未返回?cái)?shù)值的情況(這樣就不會拋出錯誤了)
String 字符串可以由"" 或 "" 表示。 ES中字符串是不可改變的,也就是說,字符串一旦創(chuàng)建,它們的值就不能改變。要改變某個變量保存的字符串,首先要銷毀原來的字符串,然后再用另一個包含新值的字符串填充該變量。
? 這五種基本數(shù)據(jù)類型是按值訪問的,因?yàn)榭梢圆僮鞅4嬖谧兞恐械膶?shí)際的值。
復(fù)雜類型(引用類型)
Object 對象其實(shí)就是一組數(shù)據(jù)和功能的集合。對象可以通過new操作符后跟要創(chuàng)建的對象類型的名稱來創(chuàng)建。 而創(chuàng)建Object的實(shí)例并為其添加屬性和方法,就可以自定義對象。
Object類型
Array類型
Date類型
RegExp類型
Function類型
? 引用類型的值是保存在內(nèi)存中的對象。與其他語言不同,js不允許直接訪問內(nèi)存中的位置,也就是說不能直接操作對象的內(nèi)存空間。 操作對象時,實(shí)際上是在操作對象的引用而不是實(shí)際的對象。(這種說法不太嚴(yán)謹(jǐn),為對象添加屬性時,操作的是實(shí)際的對象)。
值類型與引用類型的差別基本類型在內(nèi)存中占據(jù)固定大小的空間,因此被保存在棧內(nèi)存中
從一個變量向另一個變量復(fù)制基本類型的值,復(fù)制的是值的副本
引用類型的值是對象,保存在堆內(nèi)存
包含引用類型值的變量實(shí)際上包含的并不是對象本身,而是一個指向該對象的指針
從一個變量向另一個變量復(fù)制引用類型的值的時候,復(fù)制是引用指針,因此兩個變量最終都指向同一個對象
判斷數(shù)據(jù)類型 使用typeof檢測基本數(shù)據(jù)類型的最佳選擇是使用typeof
var bool = true var num = 1 var str = "abc" var und = undefined var nul = null var arr = [1,2,3] var obj = {} var fun = function(){} var reg = new RegExp() console.log(typeof bool); //boolean console.log(typeof num); //number console.log(typeof str); //string console.log(typeof und); //undefined console.log(typeof nul); //object console.log(typeof arr); //object console.log(typeof obj); //object console.log(typeof reg); //object console.log(typeof fun); //function 由結(jié)果可知,除了在檢測null時返回 object 和檢測function時放回function。對于引用類型返回均為object使用instanceof
檢測引用型數(shù)據(jù)類型時的最佳選擇是instanceof
console.log(reg instanceof Object); //true console.log(reg instanceof RegExp); //true 因?yàn)楦鶕?jù)規(guī)定,所用引用類型的值都是Object的實(shí)例,因此都是返回true console.log(bool instanceof Boolean); //false var bool2 = new Boolean(); console.log(bool2 instanceof Boolean); //true 引用類型與基本包裝類型的主要區(qū)別就是對象的生存期。使用new操作符創(chuàng)建的引用類型的實(shí)例,在執(zhí)行流離開當(dāng)前作用域之前都是一直保存在內(nèi)存中。而自動創(chuàng)建的基本包裝類型的對象,則只存在于一行代碼的執(zhí)行瞬間,然后立即被銷毀
console.log(und instanceof Object); // false console.log(nul instanceof Object); // false undefined和null沒有contructor屬性 instanceof它不僅檢測構(gòu)造找個對象的構(gòu)造器,還檢測原型鏈。所以它可以檢測繼承而來的屬性。使用constructor
console.log(bool.constructor === Boolean);// true console.log(num.constructor === Number);// true console.log(str.constructor === String);// true console.log(arr.constructor === Array);// true console.log(obj.constructor === Object);// true console.log(fun.constructor === Function);// true undefined和null沒有contructor屬性 constructor不能判斷undefined和null,并且使用它是不安全的,因?yàn)閏ontructor的指向是可以改變的 //詳情請了解js對象的特性使用Object.prototype.toString.call
console.log(Object.prototype.toString.call(bool));//[object Boolean] console.log(Object.prototype.toString.call(num));//[object Number] console.log(Object.prototype.toString.call(str));//[object String] console.log(Object.prototype.toString.call(und));//[object Undefined] console.log(Object.prototype.toString.call(nul));//[object Null] console.log(Object.prototype.toString.call(arr));//[object Array] console.log(Object.prototype.toString.call(obj));//[object Object] console.log(Object.prototype.toString.call(fun));//[object Function]
博客參考
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/106407.html
摘要:定義運(yùn)算符用來判斷一個構(gòu)造函數(shù)的屬性所指向的對象是否存在另外一個要檢測對象的原型鏈上,用于引用類型。但其實(shí),實(shí)例的來自于構(gòu)造函數(shù)的。 一、關(guān)于css 樣式優(yōu)先級: 行內(nèi)樣式>id選擇器樣式>類選擇器樣式>標(biāo)簽選擇器樣式>通配符選擇器的樣式>繼承樣式>默認(rèn)樣式 二、關(guān)于js 關(guān)于問題:**JavaScript中的所有事物都是對象??** 從typeof和instanceo...
摘要:最常見的判斷方法它的官方解釋操作符返回一個字符串,表示未經(jīng)計(jì)算的操作數(shù)的類型。另外,是判斷對象是否屬于某一類型,而不是獲取的對象的類型。多個窗口意味著多個全局環(huán)境,不同的全局環(huán)境擁有不同的全局對象,從而擁有不同的內(nèi)置類型構(gòu)造函數(shù)。 js中的數(shù)據(jù)類型 js中只有六種原始數(shù)據(jù)類型和一個Object: Boolean Null Undefined Number String Symbol ...
摘要:中九個內(nèi)置對象在規(guī)范中定義了六種數(shù)據(jù)類型其中原始值類型有種,引用類型有種一有包裝對象數(shù)值型,包括整形和浮點(diǎn)型其中都是類型二有包裝對象字符串類型,有兩種表示方式,雙引號單引號。方法可以將任意類型數(shù)據(jù)轉(zhuǎn)成字符串。 JS中九個內(nèi)置對象 showImg(https://segmentfault.com/img/bV6iZG?w=481&h=411); 在ECMAScript規(guī)范(ES5)中定義...
摘要:基本數(shù)據(jù)類型在中,基本數(shù)據(jù)類型有種,即數(shù)值字符串布爾值。兩個布爾值轉(zhuǎn)為數(shù)值進(jìn)行比較。對于對象和布爾值,調(diào)用它們的方法得到對應(yīng)的字符串值,然后進(jìn)行字符串相加。減法對于字符串布爾值或者,自動調(diào)用,轉(zhuǎn)換結(jié)果若為,那么最終結(jié)果為。 這篇文章,來聊聊 JS 中的數(shù)據(jù)類型與變量。這是在學(xué)習(xí) JS 時最基礎(chǔ)的一類問題,但卻很重要。希望我的分享有幫助到你。 文章開頭,我先提幾個面試中遇到的問題: 比如...
摘要:和這三種基本的數(shù)據(jù)類型,都有對應(yīng)的引用包裝類型和。應(yīng)用于引用類型的判斷,所以對于這三類基本類型沒有什么意義。 JS 中的類型判斷 js中的數(shù)據(jù)類型 基本數(shù)據(jù)類型 undefined、number、string、boolean 引用數(shù)據(jù)類型 null、Object、Number、String、Boolean、Function、Array、Date、RegExp、Error、Argumen...
摘要:基本數(shù)據(jù)類型引用類型判斷數(shù)據(jù)類型的方法判斷中的數(shù)據(jù)類型有一下幾種方法接下來主要比較一下這幾種方法的異同。通常情況下用判斷就可以了,遇到預(yù)知類型的情況可以選用或方法實(shí)在沒轍就使用方法。 基本數(shù)據(jù)類型:String、Number、Boolean、Symbol、undefined、Null引用類型:Object Array Function 判斷數(shù)據(jù)類型的方法: 判斷js中的數(shù)據(jù)類型有一...
閱讀 2719·2023-04-25 14:59
閱讀 912·2021-11-22 11:59
閱讀 651·2021-11-17 09:33
閱讀 2479·2021-09-27 13:34
閱讀 3919·2021-09-09 11:55
閱讀 2334·2019-08-30 15:44
閱讀 1142·2019-08-30 14:06
閱讀 1939·2019-08-29 16:55