成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

再也不用擔(dān)心 JavaScript 的數(shù)據(jù)類型轉(zhuǎn)換了

opengps / 759人閱讀

摘要:運(yùn)算符返回一個(gè)布爾值,用于測(cè)試構(gòu)造函數(shù)的屬性是否存在于對(duì)象原型鏈上。定義構(gòu)造函數(shù),因?yàn)?,不在的原型鏈上類型轉(zhuǎn)換任意數(shù)據(jù)類型之間可以相互轉(zhuǎn)換,但是特殊。自動(dòng)轉(zhuǎn)換自動(dòng)轉(zhuǎn)換就是沒有顯式地使用函數(shù)對(duì)數(shù)據(jù)進(jìn)行類型轉(zhuǎn)換。

JavaScript 是一種弱類型或者說動(dòng)態(tài)類型語言。所以你不用提前聲明變量的類型,在程序運(yùn)行時(shí),類型會(huì)被自動(dòng)確定,你也可以使用同一個(gè)變量保存不同類型的數(shù)據(jù)。

數(shù)據(jù)類型 原始類型

在 JS 中一共 6 種原始類型:

string

number

boolean

undefined

null

symbol (ECMAScript 6)

對(duì)象類型
除了原始類型其他的都是對(duì)象類型(object)了。
內(nèi)存空間
在 JS 中,每一個(gè)數(shù)據(jù)都需要存放在內(nèi)存空間中。

原始類型數(shù)據(jù)直接存儲(chǔ)在 棧內(nèi)存(stack) 中,對(duì)象數(shù)據(jù)存儲(chǔ)在 堆內(nèi)存(heap) 中,并在 棧內(nèi)存 中存放了該對(duì)象數(shù)據(jù)在 堆內(nèi)存地址(引用)

var a1 = 0  // 棧
var a2 = "this is string"  // 棧
var a3 = null  // 棧

var b = { m: 20 }  // 堆
var c = [1,2,3]  // 堆

上述變量的內(nèi)存圖解:

typeof 與 instanceof
typeof 是否能正確判斷類型?instanceof 能正確判斷對(duì)象的原理是什么?
typeof
typeof 運(yùn)算符返回一個(gè)字符串,表示未經(jīng)計(jì)算的操作數(shù)的類型。

對(duì)于原始類型,除了 null 類型都顯示正確類型。

typeof "1"  // "string"
typeof true // "boolean"
typeof 1    // "number"
typeof undefined  // "undefined"
typeof Symbol()  // "symbol"

typeof null // "object" 這是一個(gè) Bug 

typeof 1 === "number"  // true
typeof (typeof 1) === "string"  // true

對(duì)于對(duì)象來說,除了函數(shù)都會(huì)顯示 object 。

typeof []   // "object"
typeof {}   // "object"
typeof console.log  // `function`
instanceof
instanceof 運(yùn)算符返回一個(gè)布爾值,用于測(cè)試構(gòu)造函數(shù)的 prototype 屬性是否存在于對(duì)象原型鏈上。所以在判斷對(duì)象的正確類型時(shí)可以考慮使用 instanceof 。
// 定義構(gòu)造函數(shù)
function A() {}
function B() {}

var a = new A()
var b = new B()

a instanceof A  // true ,因?yàn)?Object.getPrototypeOf(a) === a.prototype

a instanceof B  // false ,B.prototype 不在 a 的原型鏈上
類型轉(zhuǎn)換
任意數(shù)據(jù)類型之間可以相互轉(zhuǎn)換,但是 symbol 特殊。symbol 類型只能轉(zhuǎn)換成 string 類型,其他的轉(zhuǎn)換會(huì)報(bào)錯(cuò)。
強(qiáng)制轉(zhuǎn)換 Number()

原始類型 ---> 數(shù)字

// 1. 字符串 ---> 數(shù)字
  
    // 1) 可以被解析成數(shù)值的字符串 返回 數(shù)值
    Number("123")  // 123
    // 2) 不能解析成數(shù)值的字符串 返回 NaN
    Number("123aaa")  // NaN
    // 3) 空串 ---> 0
    Number("")  // 0

// 2. 布爾值 ---> 數(shù)字

    // 1) true ---> 1
    Number(true)  // 1
    // 2) false ---> 0
    Number(false)  // 0

// 3. undefined ---> NaN
    Number(undefined)  // NaN
    
// 4. null ---> 0
Number(null)  // 0

在瀏覽器環(huán)境中,window.parseInt()window.parseFloat() 可以將一些字符串轉(zhuǎn)換成數(shù)字,但沒 Number() 嚴(yán)格 。把其他原始類型都會(huì)轉(zhuǎn)換成 NaN 。

parseInt("123aaa")  // 123
parseFloat("1.23aaa")  // 1.23
parseInt(true)  // NaN

對(duì)象 ---> 數(shù)字

Number() 方法的參數(shù)是對(duì)象時(shí),一般情況下,除非是包含單個(gè)數(shù)字的數(shù)組會(huì)返回?cái)?shù)字,否則返回 NaN

Number({a: 1})  // NaN
Number([1,2])   // NaN
Number([1])     // 1

在執(zhí)行 Number(對(duì)象) 方法時(shí),會(huì)先進(jìn)行參數(shù)處理,將對(duì)象轉(zhuǎn)換成原始類型,再進(jìn)行轉(zhuǎn)換成數(shù)字的操作。

第一步,調(diào)用對(duì)象自身的 valueOf() 方法( var a = new String(123); a.valueOf() --> "123" )。如果返回的值是原始類型,則直接將該值轉(zhuǎn)換成數(shù)字并返回。不再進(jìn)行后續(xù)步驟。

第二步,如果 valueOf() 方法返回的是對(duì)象,則調(diào)用原對(duì)象自身的 toString() 方法,如果此時(shí)返回的值是原始類型,則將該值轉(zhuǎn)換成數(shù)字并返回,不再進(jìn)行后續(xù)操作。

如果 toString() 方法返回的還是對(duì)象,就報(bào)錯(cuò)。

Number({a: 1})  // NaN
// 過程如下:
var t = {a: 1}
// 第一步
t.valueOf()  // {a: 1}
// 第二步
t.toString() // "[object Object]"
Number("[object Object]")  // NaN
    
Number([1,2])
//過程如下:
// 第一步
[1,2].valueOf()   // [1,2]
// 第二步
[1].toString()  // "1,2"
Number("1,2")     // NaN
    
// 再來看看參數(shù)是單個(gè)數(shù)字的數(shù)組時(shí)的情況
    
Number([1])  // 1
    
//過程如下:
// 第一步
[1].valueOf()   // [1]
// 第二步
[1].toString()  // "1"
Number("1")     // 1
String()
String() 函數(shù)可以將任意類型的值轉(zhuǎn)換成字符串。

原始類型 ---> 字符串

var a = Symbol({})
String(a)  // "Symbol([object Object])"

String(Symbol([]))  // "Symbol()"

對(duì)象 ---> 字符串

數(shù)組會(huì)返回該數(shù)組的字符串形式,函數(shù)返回完整函數(shù)的字符串,其他的返回一個(gè)類型字符串。

String([1,2])  // "1,2"
String([])  // ""

function foo(x){ return x*x }
String(foo)  //  "function foo(x){ return x*x }"

String({a: 1})  // "[object Object]"

String(對(duì)象) 方法的轉(zhuǎn)換規(guī)則與 Number(對(duì)象) 基本相同,只是互換了 valueOf()toString() 的執(zhí)行順序。

先調(diào)用對(duì)象的 toString() 方法。如果返回的值是原始類型,則將該值轉(zhuǎn)換成字符串并返回。不再執(zhí)行以下步驟。

如果 toString() 返回的是對(duì)象,則調(diào)用原對(duì)象的 valueOf() 方法。如果返回的值是原始類型,將該值轉(zhuǎn)換成字符串并返回。不再執(zhí)行后續(xù)操作。

如果 valueOf() 方法返回的還是對(duì)象,就報(bào)錯(cuò)。

自定義對(duì)象的 toString() 方法和 valueOf() 方法:

var obj = {
    valueOf: function() {
        return 1
    },
    toString: function() {
        return 2
    }
}

String(obj)  // "2"
Number(obj)  // 1
Boolean()
Boolean() 函數(shù)可以將任意類型轉(zhuǎn)換成布爾值
除了以下五個(gè)值轉(zhuǎn)換結(jié)果為 false ,其他值全部轉(zhuǎn)換為 true

undefined

null

"" (空字符串)

-00

NaN

!!數(shù)據(jù)Boolean(數(shù)據(jù)) 效果一樣。
Boolean(undefined)  // false
Boolean(null)  // false
Boolean("")  // false
Boolean(0)  // false
Boolean(NaN)  // false

! NaN  // true
!! NaN  // false
自動(dòng)轉(zhuǎn)換
自動(dòng)轉(zhuǎn)換就是沒有顯式地使用函數(shù)對(duì)數(shù)據(jù)進(jìn)行類型轉(zhuǎn)換。但它是以強(qiáng)制轉(zhuǎn)換為基礎(chǔ)的。

當(dāng)預(yù)期數(shù)值與實(shí)際數(shù)值不匹配時(shí),JavaScript 就會(huì)自動(dòng)調(diào)用預(yù)期類型的轉(zhuǎn)換函數(shù)對(duì)實(shí)際值進(jìn)行轉(zhuǎn)換。

進(jìn)行算術(shù)運(yùn)算

運(yùn)算子都是原始類型

在加法運(yùn)算中 只要一方時(shí)字符串,另一方就會(huì)轉(zhuǎn)換成字符串。這是字符串拼接。

其他 - * / ** % ++ -- +(一元運(yùn)算符 表示正數(shù)) -(一元運(yùn)算符 表負(fù)數(shù)) 都會(huì)將運(yùn)算子轉(zhuǎn)換成數(shù)字。

1 + "1"  // "11"
2 * "3"  // 6
1 - "a"  // NaN  
3 + - "1"  // 2

運(yùn)算子是對(duì)象

會(huì)先把對(duì)象轉(zhuǎn)換成原始類型再按預(yù)期值轉(zhuǎn)換。具體方法是:先調(diào)用對(duì)象的 valueOf() 方法試圖將對(duì)象轉(zhuǎn)換成原始類型,如果返回的是對(duì)象,就再調(diào)用原對(duì)象的 toString() 方法,如果返回的還是對(duì)象就報(bào)錯(cuò)。

var obj = {
    valueOf: function() {
        return "1"
    },
    toString: function() {
        return "10"
    }
}

10 - obj  // 9

1 + [1,2]  // "11,2"
// [1,2].toString() ---> "1,2"
進(jìn)行比較運(yùn)算

===!== 不會(huì)發(fā)生類型轉(zhuǎn)換,只要類型不同就返回 false.

兩邊同時(shí)為字符串會(huì)比較 Unicode 碼,否則都會(huì)轉(zhuǎn)換成數(shù)字進(jìn)行比較(null、undefined 除外)。

NaN 與任意值(包括本身NaN)比較都返回 false

null undefined 除了 null(undefined) == undefined(null) 返回 true,其他 > < ==nullundefined 參與的都返回 false 。

"abc" > "abd"  // false
true > false  // true  ---> Number(true) > Number(false)
true > "-1"  // true  ---> Number(true) > Number("-1")

var obj = {valueOf: function() {return "1"}}
[3] > obj  // true
// 過程如下:
// Number([3]) > Number(obj)
// Number("3") > Number("1")
// 3 > 1

0 == null  // false

== 常用于判斷函數(shù)的參數(shù)是否等于 null 或者 undefined ,因?yàn)?null == undefinded 返回 true

function fun(x) {
    if(x == null) {···}
} 
邏輯運(yùn)算

!參數(shù)

參數(shù)&&

參數(shù)||

參數(shù)? :(三元運(yùn)算符)

if(參數(shù))

都會(huì)將非布爾的參數(shù)轉(zhuǎn)換成布爾類型(使用 Boolean(參數(shù)) 函數(shù))。

閱讀原文

參考資料:

https://wangdoc.com/javascript/features/conversion.html

https://juejin.im/book/5bdc715fe51d454e755f75ef/section/5bdc715f6fb9a049c15ea4e0

https://juejin.im/entry/589c29a9b123db16a3c18adf

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/109098.html

相關(guān)文章

  • JavaScript核心概念(1):類型轉(zhuǎn)換

    摘要:核心內(nèi)置類,會(huì)嘗試先于可以理解為對(duì)象優(yōu)先轉(zhuǎn)換成數(shù)字例外的是,利用的是轉(zhuǎn)換。非核心的對(duì)象,通過自己的實(shí)現(xiàn)中定義的方法轉(zhuǎn)換成原始值。 本文首發(fā)于個(gè)人博客 showImg(https://segmentfault.com/img/remote/1460000015954811?w=639&h=724); 看到這個(gè)是不是有一種想打人的感覺,垃圾 JavaScript,這特么都什么鬼,相信很多...

    tracymac7 評(píng)論0 收藏0
  • API

    摘要:是一個(gè)極度純凈的上傳插件,通過簡(jiǎn)單調(diào)整就可以融入到任何項(xiàng)目,支持多文件上傳上傳速率動(dòng)態(tài)控制真實(shí)進(jìn)度監(jiān)控分塊生成分塊上傳校驗(yàn)秒傳暫停取消等。 跨域?qū)W習(xí)筆記 前言: 當(dāng)一個(gè)資源,向與之所在服務(wù)器不同的域或端口請(qǐng)求另一個(gè)資源時(shí),這個(gè)HTTP請(qǐng)求,我們認(rèn)為是跨域的請(qǐng)求。出于安全考慮,瀏覽器會(huì)限制腳本發(fā)起的跨域HTTP請(qǐng)求。 那天后端讓我把token放到http請(qǐng)求頭字段里,說是為了和RN端統(tǒng)一...

    lsxiao 評(píng)論0 收藏0
  • WeexBox 1.2.0 新增 Lottie 動(dòng)畫,媽媽再也不用擔(dān)心我加班寫動(dòng)畫!

    摘要:官方群號(hào)背景官方提供了模塊可以用來在組件上執(zhí)行動(dòng)畫,但是它的功能有限還容易造成卡頓。它通過做成動(dòng)畫導(dǎo)出文件,然后前端使用直接加載文件生成動(dòng)畫,不需要前端進(jìn)行復(fù)雜的繪制等操作。多現(xiàn)成可用的優(yōu)秀動(dòng)畫在這里中使用因?yàn)樘?jiǎn)單,我就直接貼代碼了。 showImg(https://segmentfault.com/img/bVbntuK?w=300&h=300); WeexBox官方QQ群號(hào):94...

    szysky 評(píng)論0 收藏0
  • JavaScript Promise

    摘要:前言假如需要向后端發(fā)送一個(gè)請(qǐng)求,并對(duì)返回的數(shù)據(jù)進(jìn)行操作,可能我們第一時(shí)間想到的是回調(diào)函數(shù)。如果值本身就是一個(gè)對(duì)象,則替代默認(rèn)的對(duì)象作為返回值如果值為其他值,則將這個(gè)值作為返回的的函數(shù)的參數(shù)值。 前言 假如需要向后端發(fā)送一個(gè)請(qǐng)求,并對(duì)返回的數(shù)據(jù)進(jìn)行操作,可能我們第一時(shí)間想到的是回調(diào)函數(shù)。但如果接著又需要執(zhí)行第二個(gè)、第三個(gè)...第n個(gè)異步操作,那么回調(diào)函數(shù)就會(huì)一層層的嵌套,嚴(yán)重影響了代碼可...

    Tamic 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<