JavaScript學習之數據類型(1)

1.簡介

JavaScript 的數據類型有6種

  • 數值(number):整數和小數(比如1和3.14)
  • 字符串(string): 文本(比如Hello World)。
  • 布爾值(boolean): 即* true(真)和false(假)
  • undefined: 表示“未定義”或不存在
  • null: 表示空值,即此處的值為空。
  • 對象(object): 各種值組成的集合。

1.數值,字符串,布爾值這三種類型,全稱為原始類型(primitive type)的值,不可再細分
2.對象則稱為合成類型(complex type)的值,
3.undefinednull,特殊值

JavaScript 有三種方法,可以確定一個值到底是什么類型。分別是typeof運算符,instanceof運算符,Object.prototype.toString方法

typeof 123 //"number"
typeof abc //"undefined" 因為abc沒有未定義
typeof 'abc' //"string"
typeof false //"boolean"
typeof null //"object"

2.null 和 undefined

1.類型不一樣:
console.log(typeOf undefined);//undefined
console.log(typeOf null);//object

2.轉化為值時不一樣:undefined為NaN ,null為0
console.log(Number(undefined));//NaN
console.log(Number(10+undefined));//NaN
console.log(Number(null));//0
console.log(Number(10+null));//10

3.比較
undefined === null;//false
undefined == null;//true

3.布爾值(boolean)

真用true表示,假用false表示
false,undefined,null,0,NaN,""''(空字符串) 這幾個值都會被轉換為false
空數組([])和空對象({})對應的布爾值,都是true

4.數值(number)

JavaScript內部所有的數字都是以64位浮點數形式儲存,因此

1 === 1.0 //true

JavaScript 浮點數在計算中要注意精度問題

0.1 + 0.2 == 0.3 // false
0.3 / 0.1 //2.9999999999999996
(0.3 - 0.2) === (0.2 - 0.1) //false

4.1數值的精度

JavaScript 浮點數的64個二進制位,從最左邊開始

  • 第1位:符號位,0表示正數,1表示負數
  • 第2位到第12位(共11位):指數部分
  • 第13位到第64位(共52位):小數部分(即有效數字)

符號位決定了一個數的正負,指數部分決定了數值的大小,小數部分決定了數值的精度,指數位有11個二進制位,因此通過Math.pow(2,11)可算出范圍是0~2047, IEEE 754 規定,如果指數部分的值在0~2047之間(不含兩個端點,那么有效數字的第一位默認總是1,也就是說,有效數字這時總是1.xx...xx的形式,其中xx..xx的部分保存在64位浮點數之中,最長可能為52位。因此,JavaScript 提供的有效數字最長為53個二進制位。

公式
(-1)^符號位 * 1.xx...xx * 2^指數部分

因此JavaScrip能夠表示的數的精度范圍是-2^53 到2^53

Math.pow(2, 53) // 9007199254740992 
Math.pow(2, 53) + 1 // 9007199254740992 精度不準
Math.pow(-2, 53) //-9007199254740992 
Math.pow(-2, 53) - 1 //-9007199254740992 精度不準

4.2 數值范圍

64位浮點數的指數部分的值最大為2047,正負數各占一半,因此JavaScript 能夠表示的數值范圍為2^1024 ~ 2^-1023(開區間),如果一個數大于等于2的1024次方,就會發生“正向溢出”,返回值為Infinity

Math.pow(2, 1024) // Infinity

如果一個數小于等于2的-1024次方,就會發生“逆向溢出”,返回值為0

Math.pow(2, -1075) // 0
Number.MAX_VALUE //1.7976931348623157e+308
Number.MIN_VALUE // 5e-324

4.3數值的表示法

當以下兩種情況時,JavaScript會自動轉化為科學計數法

  • 小數點前的數字多余21個
1234567890123456789012   //輸出 1.2345678901234568e+21

123456789012345678901   //輸出 123456789012345680000
  • 小數點后的零多于5個
0.0000001 // 1e-7
0.000001 //0.000001

4.4數值的進制

  • 十進制:我們平時正常用的數字
  • 二進制:前綴0b0B
  • 八進制:前綴0O0o 或者只用了前導0,且只用了0~7的八個阿拉伯數字
  • 十六進制:前綴0x0X

4.5特殊數值

4.5.1 正零和負零

除了正零和負零做分母的時候值不同,其他時候正零和負零是一樣的

(1 / +0) === (1 / -0) // false

是因為除以正零得到+Infinity,除以負零得到-Infinity,這兩者是不相等的

4.5.2 NaN

NaN是特殊值,表示"非數字"(Not a Number)

5 - 'x' // NaN

0除以0也會得到NaN

0 / 0 // NaN

NaN不等于任何值,包括它本身。

NaN === NaN // false

NaN在布爾值中是false
NaN在與任何數(包括他自己)運算時都顯示的是NaN

4.5.3 Infinity

Infinity有正負之分,Infinity表示正的無窮,-Infinity表示負的無窮
Infinitynull計算時,null會轉成0,等同于與0的計算。
Infinityundefined計算,返回的都是NaN。

Math.pow(2, 1024) // Infinity
0 / 0 // NaN
1 / 0 // Infinity
Infinity === -Infinity // false
1 / -0 // -Infinity
-1 / -0 // Infinity

4.6.與數值相關的全局方法

4.6.1 parseInt()

將字符串轉為整數。

parseInt('123') // 123

如果字符串頭部有空格,空格會被自動去除。

parseInt('   123') // 123

如果parseInt的參數不是字符串,則會先轉為字符串再轉換。

parseInt(1.23) // 1
// 等同于
parseInt('1.23') // 1

字符串轉為整數的時候,是一個個字符依次轉換,如果遇到不能轉為數字的字符,就不再進行下去,返回已經轉好的部分。

parseInt('8a') // 8
parseInt('12**') // 12
parseInt('12.34') // 12
parseInt('15e2') // 15
parseInt('15px') // 15

如果字符串的第一個字符不能轉化為數字(后面跟著數字的正負號除外),返回NaN

parseInt('abc') // NaN
parseInt('.3') // NaN
parseInt('') // NaN
parseInt('+') // NaN
parseInt('+1') // 1

所以,parseInt的返回值只有兩種可能,要么是一個十進制整數,要么是NaN

parseInt方法還可以接受第二個參數(2 ~ 36)之間的整數,表示被解析的值的進制,返回該值對應的十進制數,如果超出這個范圍,則返回NaN。如果第二個參數是0undefinednull,則直接忽略。

parseInt('100') // 100
// 等同于
parseInt('100', 10) // 100

parseInt('100', 2) // 4  二進制數100轉化成十進制數 結果為4
parseInt('100', 6) //36
parseInt('100', 8) // 64

如果字符串包含對于指定進制無意義的字符,則從最高位開始,只返回可以轉換的數值。如果最高位無法轉換,則直接返回NaN。

parseInt('1234', 2) // 1 
parseInt('234', 2) // NaN

4.6.2 parseFloat()

將字符串轉為浮點數

parseFloat('3.14') // 3.14
parseFloat('314e-2') // 3.14
parseFloat('0.0314E+2') // 3.14

如果字符串包含不能轉為浮點數的字符,則不再進行往后轉換,返回已經轉好的部分。

parseFloat('8.88lalala') // 8.88
parseFloat('\t\v\r12.34\n ') // 12.34

如果參數不是字符串,或者字符串的第一個字符不能轉化為浮點數,則返回NaN。

4.6.3 isNaN()

判斷一個值是否為NaN
isNaN只對數值有效,如果傳入其他值,會被先轉成數值

isNaN(NaN) // true 
isNaN(123) // false

isNaNtrue的值,有可能不是NaN,而是一個字符串

isNaN('Hello') // true
// 相當于
isNaN(Number('Hello')) // true

對于對象和元素為字符的數組,isNaN也返回true

isNaN({}) // true
// 等同于
isNaN(Number({})) // true

isNaN(['xzy']) // true
// 等同于
isNaN(Number(['xzy'])) // true

對于空數組和只有一個數值成員的數組,isNaN返回false,因為這些數組能被Number函數轉成數值

isNaN([]) // false
isNaN([123]) // false
isNaN(['123']) // false

判斷NaN的方法

function myIsNaN(value) {
  return typeof value === 'number' && isNaN(value);
}

//更可靠
function myIsNaN(value) {
  return value !== value;
}

4.6.4 isFinite()

表示某個值是否為正常的數值,返回一個布爾值.

isFinite(Infinity) // false
isFinite(-Infinity) // false
isFinite(NaN) // false
isFinite(undefined) // false
isFinite(null) // true
isFinite(-1) // true

除了Infinity、-Infinity、NaNundefined這幾個值會返回falseisFinite對于其他的數值都會返回true

5 字符串

字符串就是零個或多個排在一起的字符,放在單引號或雙引號之中

'I like China'
'It's a sunny day'
'key = "value"' //key = "value"

單引號中用單引號,要使用'\'轉義,雙引號同理

'she is so \'sad\''     //she is so 'sad'
"she is so \"sad\""    //she is so "sad"

字符串默認只能寫在一行內 分成多行將會報錯

' a
b
' //Uncaught SyntaxError: Invalid or unexpected token

如果要換行寫,則可以在每一行的尾部使用反斜杠
'a \
b \
c \ ';  //a b c

連接運算符(+)可以連接多個單行字符串

console.log('a' + 'b' + 'c')  //abc

如果想輸出多行字符串,有一種利用多行注釋的變通方法

(function () { /*
a
b
c
*/}).toString().split('\n').slice(1, -1).join('\n')
//"a
//b
//c"

字符串可以被視為字符數組

var a = 'hello'
a[1]  // e

如果方括號中的數字超過字符串的長度,或者方括號中根本不是數字,則返回undefined

a[10]  //undefined  
a['x'] //undefined

length屬性

a.length //5

Base64 轉碼

JavaScript 原生提供兩個 Base64 相關的方法。這兩個方法不適合非 ASCII 碼的字符,會報錯
btoa():任意值轉為Base64編碼
atob()Base64 編碼轉為原來的值

var string = 'Hello World!';
btoa(string) // "SGVsbG8gV29ybGQh"
atob('SGVsbG8gV29ybGQh') // "Hello World!"

btoa('你好') // 報錯

要將非 ASCII 碼字符轉為Base64 編碼,必須中間插入一個轉碼環節,再使用這兩個方法。

function b64Encode(str) {
  return btoa(encodeURIComponent(str));
}

function b64Decode(str) {
  return decodeURIComponent(atob(str));
}

b64Encode('你好') // "JUU0JUJEJUEwJUU1JUE1JUJE"
b64Decode('JUU0JUJEJUEwJUU1JUE1JUJE') // "你好"

參考鏈接:https://wangdoc.com/javascript/types/index.html

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,461評論 6 532
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,538評論 3 417
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,423評論 0 375
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,991評論 1 312
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,761評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,207評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,268評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,419評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,959評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,782評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,983評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,528評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,222評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,653評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,901評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,678評論 3 392
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,978評論 2 374

推薦閱讀更多精彩內容