<em id="09ttv"></em>
    <sup id="09ttv"><pre id="09ttv"></pre></sup>
    <dd id="09ttv"></dd>

        • JS中數據類型轉換

          2020-3-19    seo達人

          JS中數據類型轉換

          目前為止,我了解到的JavaScript中共有6種類型。通過typeof關鍵字可以查看類型名稱。



          數據的類型:

          字符串:若值為字符串,則顯示為String。字符串使用單引號或雙引號括起來。在控制臺顯示為黑色。

          數字:若值為數字,則顯示為Number。在控制臺顯示為藍色。

          布爾值:若值為布爾值,則顯示為Boolean。它的值只有”true”和”false”。

          對象:若值為對象,則顯示為Object。

          未定義:若值未定義,也就是僅僅聲明,但未進行賦值,則顯示為Undefined。

          空值:若值為指向不引用對象的指針,則顯示為Null,它與Undefined不同,以后慢慢深入了解。



          以下表格詳細寫出了各種情況下相互轉換的結果,可作為輔助記憶。



          轉換為字符串 轉換為數字 轉換為布爾值 轉換為對象

          undefined “undefined” NaN false throw TypeError

          null “null” 0 false throw TypeError

          true “true” 1 new Boolean(“true”)

          false “false” 0 new Boolean(“false”)

          “” 0 false new String("")

          “1.2” 1.2 true new String(“1.2”)

          “1.2a” NaN true new String(“1.2a”)

          “aaa” NaN true new String(“aaa”)

          0 “0” false new Number(0)

          1 “1” true new Number(1)

          NaN “NaN” false new Number(NaN)

          Infinity “Infinity” true new Number(Infinity)

          [] “” 0 true

          [9] “9” 9 true

          [“a”“b”] “a,b” NaN true

          在Js中,數據類型可以相互轉換,轉換的方式有兩種,隱式轉換和強制轉換,首先來說一些隱式轉換。在進行代碼書寫時,要經常提醒自己所使用的元素是什么數據類型,在進行某些操作后是否會導致數據類型的變化,原因就是Js會對數據進行類型的隱式轉換。



          隱式轉換舉例:

          (+)加法運算的隱式轉換:加號兩邊只要出先了字符串,就自動將兩者均轉化為字符串,使兩個字符串發生“拼接”,最后生成的結果也是一個字符串;如果前后都不是字符串,則轉化為數字類型進行計算。



          (-、*、/、%)其他算數運算的隱式轉換:前后都轉化為數字類型進行計算。



          (!)邏輯非的隱式轉換:他會將他后面的變量或表達式轉換為布爾值。



          (<,>)比較運算符的轉換:如果前后存在一個數字,會對另一個轉化為數字進行比較;如果前后均為字符串,會依次比較對應字符的編碼大小,老大比老大,老二比老二,依次進行。



          (&&,||)邏輯運算符的轉換:先將前后都轉化為布爾值再進行判斷,要記住的是,只有undefined,null,0,””,NaN會轉化成為false,其他都是true。



          (== 、===)這里作為補充說明,null與Undefined相等但不全等,NaN與任何都不相等。



          強制轉換的方式:

          1.轉化為字符串

          String(里面寫待轉化的內容):沒什么好解釋的,就是強制將你所看到的轉化為你所看到的。

          toString(里面寫目標數字是幾進制),寫法為:待轉化內容.toString(目標內容是幾進制)。括號內不寫時默認為10。

          toFixed(保留小數的位數),寫法為待轉化內容.toFixed(保留小數的位數),存在精度誤差。



          2.轉化為數字

          Number(),只有所轉化內容在肉眼看到的全是數字,才會正常轉化;false會轉化為0,true會轉化為1;null會轉化為0;undefined會轉化為NaN;其他情況均為NaN。

          parseInt(待轉化內容,待轉化內容的進制方式),與toString互為逆運算,不寫的話默認為10。如果待轉化內容為字符串,若以數字開頭,可以從開始轉換到字符前為止變成數值。布爾值,undefined,null經過轉化均為NaN。

          ParseFloat(),與上面一致,不贅述。



          3.轉化為布爾值

          書寫方式為Boolean(),如果上面的隱式轉換你有好好看,這里很得不需要再寫了。


          日歷

          鏈接

          個人資料

          藍藍設計的小編 http://www.sdgs6788.com

          存檔

          久久久噜噜噜久久中文字幕色伊伊 | 久久99热这里只频精品6| 久久午夜综合久久| 蜜臀久久99精品久久久久久小说 | 国产精品狼人久久久久影院 | 亚洲精品NV久久久久久久久久 | 久久亚洲欧美国产精品| 国产精品久久久天天影视香蕉| 久久亚洲天堂| 久久国产精品成人免费| 亚洲精品久久久www| 99久久综合狠狠综合久久止| 亚洲精品第一综合99久久| 久久精品国内一区二区三区| 久久这里有精品| 99久久免费只有精品国产| 国产精品久久久香蕉| 免费观看成人久久网免费观看| 欧美伊人久久大香线蕉综合| 九九久久精品国产| 国产精品岛国久久久久| 香蕉久久av一区二区三区| 久久精品亚洲男人的天堂| 久久精品www| 国产亚洲精久久久久久无码| 一本色道久久综合狠狠躁| 久久精品人妻中文系列| 亚洲国产成人久久笫一页| 久久久久亚洲爆乳少妇无| 久久精品免费大片国产大片| 欧美激情精品久久久久| 久久国产亚洲精品麻豆| 久久99国产乱子伦精品免费| 欧美丰满熟妇BBB久久久| 亚洲精品无码专区久久久| 久久亚洲AV无码精品色午夜麻豆 | 狠狠综合久久综合中文88| 99久久国产免费福利| 精品久久久久久国产免费了| 国产精品青草久久久久福利99| 激情综合色综合久久综合|