欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

重學JS之顯示強制類型轉(zhuǎn)換詳解

 更新時間:2019年06月30日 14:14:24   作者:william  
這篇文章主要給大家介紹了關于重學JS之顯示強制類型轉(zhuǎn)換的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用JS具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧

ToString

ToString負責處理非字符串到字符串的強制類型轉(zhuǎn)換,常用的字符串化方法String()、toString()。

基本類型值的字符串化規(guī)則:

  • null轉(zhuǎn)換為'null'
  • undefined轉(zhuǎn)換為'undefined'
  • true轉(zhuǎn)化為'true'
  • 數(shù)字的字符串化遵循通用規(guī)則,極大值或者極小值采用科學計數(shù)法表示

普通對象在字符串化時,實際執(zhí)行Object.prototype.toString(),返回該對象的類型[object type],例如:

var test = {a : 'test'}
console.log(test.toString()) // '[object Object]'
console.log(String(test)) // '[object Object]'

但是當對象有自己的toString方法時,字符串化時就會調(diào)用該方法并返回該方法的返回值,例如:

var obj = {
 a: 'test',
 toString: function () {
 return 1
 }
}
console.log(obj.toString()) // 1
console.log(String(obj)) // 1

數(shù)組在做字符串化時,將數(shù)組所有元素字符串化再用","連接,例如:

var arr = [1, 2]
console.log(arr.toString()) // '1,2'
console.log(String(arr)) // '1,2'

JSON.stringify()

JSON.stringify()在將JSON對象序列化為字符串時,也涉及到了字符串化的相關規(guī)則。

對大多數(shù)簡單值來說,JSON字符串化和toString()的效果基本相同,例如:

console.log(JSON.stringify("test")) // ""test""
console.log(JSON.stringify(1)) // "1"
console.log(JSON.stringify(null)) // "null"

但是JSON.stringify()在對象中遇到function() {}、undefined、Symbol時會自動將其忽略,在數(shù)組中則會返回null,例如:

var obj1 = {
 a: undefined,
 b: function () {},
 c: Symbol()
}
console.log(JSON.stringify(obj1)) // "{}"
console.log(JSON.stringify([undefined, function () {}, 1])) // "[null, mull, 1]"

當對象執(zhí)行JSON.stringify()方法時,如果對象中存在toJSON方法,用它的返回值來進行序列化,例如:

var obj2 = { 
 a: undefined,
 b: function () {},
 c: Symbol(),
 toJSON: function () {
 return {a: 'replace'}
 }
}
console.log(JSON.stringify(obj2)) // "{"a":"replace"}"

ToNumber

ToNumber負責將非數(shù)字轉(zhuǎn)化為數(shù)字,Number()、parseInt()和parseFloat()都可以將非數(shù)字轉(zhuǎn)化為數(shù)字

Number()

Number()函數(shù)的轉(zhuǎn)換規(guī)則:

  • 如果是Boolean類型,true和false分別轉(zhuǎn)換為0和1
  • 如果是數(shù)字值,只是簡單的傳入和返回
  • 如果是null值,返回0
  • 如果是undefined,返回NaN
  • 如果是字符串,遵循下列規(guī)則:
    • 如果字符串中只包含數(shù)字,則將其轉(zhuǎn)變?yōu)槭M制數(shù)
    • 如果字符串中包含有效的浮點格式 ,則將其轉(zhuǎn)換為對應的浮點數(shù)值
    • 如果字符串中包含有效的十六進制格式,則將其轉(zhuǎn)換為相同大小的十進制數(shù)
    • 如果字符串是空,則將其轉(zhuǎn)換為0
    • 如果字符串中包含除上述格式之外的字符串,則將其轉(zhuǎn)換為NaN
  • 如果是對象,則調(diào)用對象的valueOf()方法,然后依照前面的規(guī)則轉(zhuǎn)換值。如果轉(zhuǎn)換的結果是NaN,則調(diào)用對象的toString()方法,然后再依次照前面的規(guī)則轉(zhuǎn)換返回的字符串值

例如:

console.log(Number(true)) // 1
console.log(Number(1)) // 1
console.log(Number(null)) // 0
console.log(Number(undefined)) // NaN
console.log(Number('11')) // 11
console.log(Number('1.1')) // 1.1
console.log(Number('0xf')) // 15
console.log(Number('')) // 0
var a = {
 valueOf: function () {
  return '10'
 }
}
var b = {
 toString: function () {
  return '10'
 }
}
var c = [1, 0]
c.toString = function () {
 return c.join("")
}
console.log(Number(a)) // 10
console.log(Number(b)) // 10
console.log(Number(c)) // 10

parseInt()

parseInt()轉(zhuǎn)換規(guī)則:

  • parseInt()函數(shù)在轉(zhuǎn)換字符串時,會忽略字符串前面的空格,直到找到第一個非空格字符
  • 如果第一個字符不是數(shù)字字符或者負號,parseInt()就會返回NaN
  • 如果第一個字符是數(shù)字字符,parseInt()就會繼續(xù)解析,直到解析完所有后續(xù)字符或者遇到一個非數(shù)字字符
  • 如果字符串中的第一個字符是數(shù)字字符,parseInt()也能識別各種進制數(shù)

例子:

console.log(parseInt('a')) // NaN
console.log(parseInt('11')) // 11
console.log(parseInt('11aa')) // 11
console.log(parseInt('0xf')) // 15

parseFloat()

parseFloat()轉(zhuǎn)換規(guī)則:

  • 與parseInt()函數(shù)類似,parseFloat()也是從第一個字符開始解析每一個字符,而且也是一直解析到字符串末尾,或者解析到遇見一個無效的浮點數(shù)字字符為止
  • 解析時會忽略前導的0
  • 只會解析十進制數(shù)

例子:

console.log(parseFloat('12.3a')) // 12.3
console.log(parseFloat('0xf')) // 0
console.log(parseFloat('01.1')) // 1.1

ToBoolean

布爾強制類型轉(zhuǎn)換的假值列表:

  • undefined
  • null
  • false
  • +0、-0和NaN
  • ""

除了上述列表以外的值在轉(zhuǎn)換的時候都應該是真值,強制布爾類型轉(zhuǎn)換常用Boolean()或者!!,第一個!將值強制轉(zhuǎn)為布爾類型,但同時還將真假值反轉(zhuǎn),第二個!將結果返回原值,例子:

console.log(Boolean("0")) // true
console.log(Boolean([])) // true
console.log(Boolean(undefined)) // false
console.log(!!"0") // true
console.log(!![]) // true
console.log(!!undefined) // false

總結

這篇文章對JS中的常見顯示強制類型轉(zhuǎn)換做了一個小結,希望能對大家理解有所幫助。

好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。

相關文章

  • 使用JavaScript實現(xiàn)按鈕的漣漪效果實例代碼

    使用JavaScript實現(xiàn)按鈕的漣漪效果實例代碼

    近來看到個不錯的按鈕點擊效果,當點擊時產(chǎn)生一次水波漣漪效果,挺好玩的,下面這篇文章主要給大家介紹了關于使用JavaScript實現(xiàn)按鈕漣漪效果的相關資料,需要的朋友可以參考下
    2022-11-11
  • 表單元素值獲取方式js及java方式的簡單實例

    表單元素值獲取方式js及java方式的簡單實例

    下面小編就為大家?guī)硪黄韱卧刂但@取方式js及java方式的簡單實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • js知識點總結之getComputedStyle的用法

    js知識點總結之getComputedStyle的用法

    getComputedStyle是一個可以獲取當前元素所有最終使用的CSS屬性值,下面這篇文章主要給大家介紹了關于js知識點總結之getComputedStyle用法的相關資料,需要的朋友可以參考下
    2022-10-10
  • JS中國標準時間轉(zhuǎn)化為年月日時分秒'yyyy-MM-dd hh:mm:ss'的示例詳解

    JS中國標準時間轉(zhuǎn)化為年月日時分秒'yyyy-MM-dd hh:mm:ss'的示例詳解

    這篇文章主要介紹了JS中國標準時間轉(zhuǎn)化為年月日時分秒‘yyyy-MM-dd hh:mm:ss‘的相關知識,通過示例代碼介紹了,Js各種時間轉(zhuǎn)換問題(YYYY-MM-DD 時間戳 中國標準時間),需要的朋友可以參考下
    2024-02-02
  • js獲取IP和PcName(IE)在vs中可用

    js獲取IP和PcName(IE)在vs中可用

    本文為大家介紹下js如何獲取IP和PcName在IE下測試,代碼如下,有需要的朋友可以參考下,希望對大家有所幫助
    2013-08-08
  • JavaScript中對象property的讀取和寫入方法介紹

    JavaScript中對象property的讀取和寫入方法介紹

    這篇文章主要介紹了JavaScript中對象property的讀取和寫入方法介紹,本文講解了原型繼承鏈中property的讀取、原型繼承鏈中property的寫入等內(nèi)容,需要的朋友可以參考下
    2014-12-12
  • 簡單談談axios中的get,post方法

    簡單談談axios中的get,post方法

    下面小編就為大家?guī)硪黄唵握務刟xios中的get,post方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • Prototype框架詳解

    Prototype框架詳解

    Prototype是一個JavaScript框架,旨在簡化動態(tài)Web應用程序的開發(fā)。原型被稱為作為一個單一的文件分發(fā)的prototype.js,本文給大家介紹prototype框架,感興趣的朋友一起學習吧
    2015-11-11
  • web基于瀏覽器的本地存儲方法應用

    web基于瀏覽器的本地存儲方法應用

    在客戶端存儲數(shù)據(jù)時,我們一般都用cookie(不敏感數(shù)據(jù)),但是在客戶端越來越富的今天,cookie可存儲的量(每個域最大4k)實在是小,已經(jīng)滿足不了我們的需求
    2012-11-11
  • TopList標簽和JavaScript結合兩例

    TopList標簽和JavaScript結合兩例

    TopList標簽和JavaScript結合兩例...
    2007-08-08

最新評論