JavaScript數據類型

来源:http://www.cnblogs.com/OldJack/archive/2017/05/24/6895940.html
-Advertisement-
Play Games

在JavaScript中定義了以下幾種數據類型: 字元串(String) 數字(Number) 布爾(Boolean) 數組(Array) 對象(Object) 空(Null) 未定義(Undefined) 1. 字元串 字元串是以單引號'或雙引號"括起來的任意文本: 如果'本身也是一個字元,那就可 ...


在JavaScript中定義了以下幾種數據類型:

  • 字元串(String)
  • 數字(Number)
  • 布爾(Boolean)
  • 數組(Array)
  • 對象(Object)
  • 空(Null)
  • 未定義(Undefined)

1. 字元串

字元串是以單引號'或雙引號"括起來的任意文本:

var carname="Volvo XC60";
var carname='Volvo XC60';

如果'本身也是一個字元,那就可以用""括起來:

var answer="It's alright";

如果"本身也是一個字元,那就可以用''括起來:

var answer='He is called "Johnny"';

如果字元串內部既包含'又包含"怎麼辦?可以用轉義字元\來標識,比如:

'I\'m \"OK\"!';

轉義字元\可以轉義很多字元,比如\n表示換行,\t表示製表符,字元\本身也要轉義,所以\\表示的字元就是\

多行字元串

由於多行字元串用\n寫起來比較費事,所以最新的ES6標準新增了一種多行字元串的表示方法,用反引號 ` ... ` 表示:

`這是一個
多行
字元串`;

 

模板字元串

要把多個字元串連接起來,可以用+號連接:

var name = '小明';
var age = 20;
var message = '你好, ' + name + ', 你今年' + age + '歲了!';
alert(message);

如果有很多變數需要連接,用+號就比較麻煩。ES6新增了一種模板字元串,表示方法和上面的多行字元串一樣,但是它會自動替換字元串中的變數:

var name = '小明';
var age = 20;
var message = `你好, ${name}, 你今年${age}歲了!`;
alert(message);

 

操作字元串

length

獲取字元串長度

var s = 'Hello, world!';
s.length; // 13

 

要獲取字元串某個指定位置的字元,使用類似Array的下標操作,索引號從0開始:

var s = 'Hello, world!';

s[0]; // 'H'
s[6]; // ' '
s[7]; // 'w'
s[12]; // '!'
s[13]; // undefined 超出範圍的索引不會報錯,但一律返回undefined

需要特別註意的是,字元串是不可變的,如果對字元串的某個索引賦值,不會有任何錯誤,但是,也沒有任何效果:

var s = 'Test';
s[0] = 'X';
alert(s); // s仍然為'Test'

JavaScript為字元串提供了一些常用方法,註意,調用這些方法本身不會改變原有字元串的內容,而是返回一個新字元串:

toUpperCase

toUpperCase()把一個字元串全部變為大寫:

var s = 'Hello';
s.toUpperCase(); // 返回'HELLO'

toLowerCase

toLowerCase()把一個字元串全部變為小寫:

var s = 'Hello';
var lower = s.toLowerCase(); // 返回'hello'並賦值給變數lower
lower; // 'hello'

 

indexOf

indexOf()會搜索指定字元串出現的位置:

var s = 'hello, world';
s.indexOf('world'); // 返回7
s.indexOf('World'); // 沒有找到指定的子串,返回-1

 

lastIndexOf

lastIndexOf()從字元串尾部向頭部搜索指定字元:

var s = 'hello';
s.lastIndexOf('l');   //返回 3

substr

substr()截取字元串:

var s = 'hello';
s.substr(1,2); //返回 ‘el’
// 從索引1開始截取長度為2的字元串

substring

substring()返回指定索引區間的子串:

var s = 'hello, world'
s.substring(0, 5); // 從索引0開始到5(不包括5),返回'hello'
s.substring(7); // 從索引7開始到結束,返回'world'

trim

trim()去除字元串兩邊空格:

var s = ' hello ';
s.trim();   //返回 ‘hello’

 

charAt

charAt()獲取指定位置字元:

var s = 'hello';
s.charAt(1);   //返回 ‘e’

 

match和search

match()返回匹配字元串的數組,如果沒有匹配則返回null

search()返回匹配字元串的首字元位置索引:

var str1="welcome to the world of world JS!";
var str2=str1.match("world");
var str3=str1.search("world");
alert(str2[0]);  // 結果為"world"
alert(str3);     // 結果為15

 

slice

slice(),對字元串進行切片操作:

var str1="abcdefgh";
var str2=str1.slice(2,4);   //結果為"cd",從索引2開始,截取到索引4,不包含索引4
var str3=str1.slice(4);     //結果為"efgh",從索引4開始,截取到字元串末尾
var str4=str1.slice(2,-1);  //結果為"cdefg",從索引2開始,截取到字元串末尾,不包含末尾字元
var str5=str1.slice(-3,-1); //結果為"fg",從索引-3開始,截取到字元串末尾索引-1,不包含末尾字元

 

replace

replace(),替換字元串:

var s = 'hello,jack';
s.replace('jack', 'michael');   //返回‘hello,michael’

 

split

split(),分割字元串:

var str1="一,二,三,四,五,六,日";
var strArray=str1.split(",");   //返回數組:["一", "二", "三", "四", "五", "六", "日"]

2. 數字(Number)

JavaScript不區分整數和浮點數,統一用Number表示,以下都是合法的Number類型:

123; // 整數123
0.456; // 浮點數0.456
1.2345e3; // 科學計數法表示1.2345x1000,等同於1234.5
-99; // 負數
NaN; // NaN表示Not a Number,當無法計算結果時用NaN表示
Infinity; // Infinity表示無限大,當數值超過了JavaScript的Number所能表示的最大值時,就表示為Infinity

電腦由於使用二進位,所以,有時候用十六進位表示整數比較方便,十六進位用0x首碼和0-9,a-f表示,例如:0xff000xa5b4c3d2,等等,它們和十進位表示的數值完全一樣。

2進位: 1111 0011 1101 0100   <-----> 16進位:0xF3D4 <-----> 10進位:62420
2進位: 1 111 001 111 010 100 <-----> 8進位:0171724

 

3. 布爾值(Boolean)

布爾值和布爾代數的表示完全一致,一個布爾值只有truefalse兩種值,要麼是true,要麼是false,可以直接用truefalse表示布爾值,實際運算中true=1,false=0,也可以通過布爾運算計算出來:

true; // 這是一個true值
false; // 這是一個false值
2 > 1; // 這是一個true值
2 >= 3; // 這是一個false值

 

4. 數組(Array)

a. 定義數組

數組是一組按順序排列的集合,集合的每個值稱為元素。JavaScript的數組可以包括任意數據類型。例如:

[1, 2, 3.14, 'Hello', null, true];

上述數組包含6個元素。數組用[]表示,元素之間用,分隔。

另一種創建數組的方法是通過Array()函數實現:

new Array(1, 2, 3); // 創建了數組[1, 2, 3]

然而,出於代碼的可讀性考慮,強烈建議直接使用[]

數組的元素可以通過索引來訪問。請註意,索引的起始值為0

var arr = [1, 2, 3.14, 'Hello', null, true];
arr[0]; // 返回索引為0的元素,即1
arr[5]; // 返回索引為5的元素,即true
arr[6]; // 索引超出了範圍,返回undefined

b. 數組的屬性和方法

要取得Array的長度,直接訪問length屬性:

var arr = [1, 2, 3.14, 'Hello', null, true];
arr.length; // 6

請註意,直接給Arraylength賦一個新的值會導致Array大小的變化:

var arr = [1, 2, 3];
arr.length; // 3
arr.length = 6;
arr; // arr變為[1, 2, 3, undefined, undefined, undefined]
arr.length = 2;
arr; // arr變為[1, 2]

Array可以通過索引把對應的元素修改為新的值,因此,對Array的索引進行賦值會直接修改這個Array

var arr = ['A', 'B', 'C'];
arr[1] = 99;
arr; // arr現在變為['A', 99, 'C']

 

請註意,如果通過索引賦值時,索引超過了範圍,同樣會引起Array大小的變化:

var arr = [1, 2, 3];
arr[5] = 'x';
arr; // arr變為[1, 2, 3, undefined, undefined, 'x']

大多數其他編程語言不允許直接改變數組的大小,越界訪問索引會報錯。然而,JavaScript的Array卻不會有任何錯誤。在編寫代碼時,不建議直接修改Array的大小,訪問索引時要確保索引不會越界。

indexOf

與String類似,Array也可以通過indexOf()來搜索一個指定的元素的位置:

var arr = [10, 20, '30', 'xyz'];
arr.indexOf(10); // 元素10的索引為0
arr.indexOf(20); // 元素20的索引為1
arr.indexOf(30); // 元素30沒有找到,返回-1
arr.indexOf('30'); // 元素'30'的索引為2

 

slice

slice()就是對應String的substring()版本,它截取Array的部分元素,然後返回一個新的Array

var arr = ['A', 'B', 'C', 'D', 'E', 'F', 'G'];
arr.slice(0, 3); // 從索引0開始,到索引3結束,但不包括索引3: ['A', 'B', 'C']
arr.slice(3); // 從索引3開始到結束: ['D', 'E', 'F', 'G']

註意到slice()的起止參數包括開始索引,不包括結束索引。

如果不給slice()傳遞任何參數,它就會從頭到尾截取所有元素。利用這一點,我們可以很容易地複製一個Array

var arr = ['A', 'B', 'C', 'D', 'E', 'F', 'G'];
var aCopy = arr.slice();
aCopy; // ['A', 'B', 'C', 'D', 'E', 'F', 'G']
aCopy === arr; // false

push和pop

push()Array的末尾添加若幹元素,pop()則把Array的最後一個元素刪除掉:

var arr = [1, 2];
arr.push('A', 'B'); // 返回Array新的長度: 4
arr; // [1, 2, 'A', 'B']
arr.pop(); // pop()返回'B'
arr; // [1, 2, 'A']
arr.pop(); arr.pop(); arr.pop(); // 連續pop 3次
arr; // []
arr.pop(); // 空數組繼續pop不會報錯,而是返回undefined
arr; // []

unshift和shift

如果要往Array的頭部添加若幹元素,使用unshift()方法,shift()方法則把Array的第一個元素刪掉:

var arr = [1, 2];
arr.unshift('A', 'B'); // 返回Array新的長度: 4
arr; // ['A', 'B', 1, 2]
arr.shift(); // 'A'
arr; // ['B', 1, 2]
arr.shift(); arr.shift(); arr.shift(); // 連續shift 3次
arr; // []
arr.shift(); // 空數組繼續shift不會報錯,而是返回undefined
arr; // []

sort

sort()可以對當前Array進行排序,它會直接修改當前Array的元素位置,直接調用時,按照預設順序排序:

var arr = ['B', 'C', 'A'];
arr.sort();
arr; // ['A', 'B', 'C']

對數字元素進行sort時,會出現未真實按照數字大小排序的情況:

arr=[1,5,2,100];
arr.sort();
console.log(arr)    // 排序結果:[1, 100, 2, 5]
//這是因為預設以字元的ASCII碼進行排序,首字元相同,則比較第2位。故並沒有按照數字的真實大小進行排序

 

解決方法:

arr=[1,5,2,100];
function intSort(a,b){
    if (a>b){
        return 1;
    }
    else if(a<b){
        return -1;
    }
    else {
        return 0
    }
}

arr.sort(intSort);

console.log(arr)    // 排序結果:[1, 2, 5, 100]

//intSort函數也可寫為如下形式
//function intSort(a,b){
//    return a-b;
//}

reverse

reverse()把整個Array的元素給反轉:

var arr = ['one', 'two', 'three'];
arr.reverse(); 
arr; // ['three', 'two', 'one']

 

splice

splice()方法是修改Array的“萬能方法”,它可以從指定的索引開始刪除若幹元素,然後再從該位置添加若幹元素:

var arr = ['Microsoft', 'Apple', 'Yahoo', 'AOL', 'Excite', 'Oracle'];
// 從索引2開始刪除3個元素,然後再添加兩個元素:
arr.splice(2, 3, 'Google', 'Facebook'); // 返回刪除的元素 ['Yahoo', 'AOL', 'Excite']
arr; // ['Microsoft', 'Apple', 'Google', 'Facebook', 'Oracle']
// 只刪除,不添加:
arr.splice(2, 2); // ['Google', 'Facebook']
arr; // ['Microsoft', 'Apple', 'Oracle']
// 只添加,不刪除:
arr.splice(2, 0, 'Google', 'Facebook'); // 返回[],因為沒有刪除任何元素
arr; // ['Microsoft', 'Apple', 'Google', 'Facebook', 'Oracle']

 

concat

concat()方法把當前的Array和另一個Array連接起來,並返回一個新的Array

var arr = ['A', 'B', 'C'];
var added = arr.concat([1, 2, 3]);
added; // ['A', 'B', 'C', 1, 2, 3]
arr; // ['A', 'B', 'C']

請註意concat()方法並沒有修改當前Array,而是返回了一個新的Array

實際上,concat()方法可以接收任意個元素和Array,並且自動把Array拆開,然後全部添加到新的Array里:

var arr = ['A', 'B', 'C'];
arr.concat(1, 2, [3, 4]); // ['A', 'B', 'C', 1, 2, 3, 4]

join

join()方法是一個非常實用的方法,它把當前Array的每個元素都用指定的字元串連接起來,然後返回連接後的字元串:

var arr = ['A', 'B', 'C', 1, 2, 3];
arr.join('-'); // 'A-B-C-1-2-3'

如果Array的元素不是字元串,將自動轉換為字元串後再連接。

5. 對象(Object) 

JavaScript的對象是一組由鍵-值組成的無序集合,例如:

var person = {
    name: 'Bob',
    age: 20,
    tags: ['js', 'web', 'mobile'],
    city: 'Beijing',
    hasCar: true,
    zipcode: null
};

JavaScript對象的鍵都是字元串類型,值可以是任意數據類型。上述person對象一共定義了6個鍵值對,其中每個鍵又稱為對象的屬性,例如,personname屬性為'Bob'zipcode屬性為null

要獲取一個對象的屬性,我們用對象變數.屬性名的方式:

person.name; // 'Bob'
person.zipcode; // null

訪問屬性是通過.操作符完成的,但這要求屬性名必須是一個有效的變數名。如果屬性名包含特殊字元,就必須用''括起來:

var xiaohong = {
    name: '小紅',
    'middle-school': 'No.1 Middle School'
};

xiaohong的屬性名middle-school不是一個有效的變數,就需要用''括起來。訪問這個屬性也無法使用.操作符,必須用['xxx']來訪問:

xiaohong['middle-school']; // 'No.1 Middle School'
xiaohong['name']; // '小紅'
xiaohong.name; // '小紅'

也可以用xiaohong['name']來訪問xiaohongname屬性,不過xiaohong.name的寫法更簡潔。我們在編寫JavaScript代碼的時候,屬性名儘量使用標準的變數名,這樣就可以直接通過object.prop的形式訪問一個屬性了。

實際上JavaScript對象的所有屬性都是字元串,不過屬性對應的值可以是任意數據類型。

如果訪問一個不存在的屬性會返回什麼呢?JavaScript規定,訪問不存在的屬性不報錯,而是返回undefined

var xiaoming = {
    name: '小明'
};
xiaoming.age; // undefined

由於JavaScript的對象是動態類型,你可以自由地給一個對象添加或刪除屬性:

var xiaoming = {
    name: '小明'
};
xiaoming.age; // undefined
xiaoming.age = 18; // 新增一個age屬性
xiaoming.age; // 18
delete xiaoming.age; // 刪除age屬性
xiaoming.age; // undefined
delete xiaoming['name']; // 刪除name屬性
xiaoming.name; // undefined
delete xiaoming.school; // 刪除一個不存在的school屬性也不會報錯

如果我們要檢測xiaoming是否擁有某一屬性,可以用in操作符:

var xiaoming = {
    name: '小明',
    birth: 1990,
    school: 'No.1 Middle School',
    height: 1.70,
    weight: 65,
    score: null
};
'name' in xiaoming; // true
'grade' in xiaoming; // false

不過要小心,如果in判斷一個屬性存在,這個屬性不一定是xiaoming的,它可能是xiaoming繼承得到的:

'toString' in xiaoming; // true

因為toString定義在object對象中,而所有對象最終都會在原型鏈上指向object,所以xiaoming也擁有toString屬性。

要判斷一個屬性是否是xiaoming自身擁有的,而不是繼承得到的,可以用hasOwnProperty()方法:

var xiaoming = {
    name: '小明'
};
xiaoming.hasOwnProperty('name'); // true
xiaoming.hasOwnProperty('toString'); // false

6. Null & Undefined類型

Undefined類型

Undefined 類型只有一個值,即 undefined。當聲明的變數未初始化時,該變數的預設值是 undefined。

當函數無明確返回值時,返回的也是值 "undefined";

Null類型

另一種只有一個值的類型是 Null,它只有一個專用值 null,即它的字面量。值 undefined 實際上是從值 null 派生來的,因此 ECMAScript 把它們定義為相等的。

儘管這兩個值相等,但它們的含義不同。undefined 是聲明瞭變數但未對其初始化時賦予該變數的值,null 則用於表示尚未存在的對象(在討論 typeof 運算符時,簡單地介紹過這一點)。如果函數或方法要返回的是對象,那麼找不到該對象時,返回的通常是 null。

 

參考資料:

1. http://www.w3cschool.cn/javascript/js-datatypes.html

2. http://www.liaoxuefeng.com/wiki/001434446689867b27157e896e74d51a89c25cc8b43bdb3000/001434499190108eec0bdf14e704a09935cd112e501e31a000

3. http://www.cnblogs.com/yuanchenqi/articles/6893904.html

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 硬體環境: CPU:AMD Phenom(tm) II X4 955 Processor Memory:8G SSD(128G):/ HDD(1T):/home/ 軟體環境: OS:Ubuntu14.04.3 LTS Java:JDK1.7 關於ReentrantLock中非公平鎖和公平鎖詳細區別以 ...
  • object對象中的 public boolean equals(Object obj),對於任何非空引用值 x 和 y,當且僅當 x 和 y 引用同一個對象時,此方法才返回 true;註意:當此方法被重寫時,通常有必要重寫 hashCode 方法,以維護 hashCode 方法的常規協定,該協定聲... ...
  • Array構造器 如果參數只有一個並且是Number類型,那麼就是指定數組的長度,但不能是NaN,如果是多個會被當做參數列表。 註意當只傳遞一個參數時,它只是指定該數組的長度,並不會去填充內容 由於傳遞一個參數時不會填充數組內容,因此forEach不會迴圈這些空內容,或者說forEach不是根據數組 ...
  • IE5 是第一款引入XHR 對象的瀏覽器。在IE5 中,XHR 對象是通過MSXML 庫中的一個ActiveX對象實現的。因此,在IE 中可能會遇到三種不同版本的XHR 對象,即MSXML2.XMLHttp、MSXML2.XMLHttp.3.0 和MXSML2.XMLHttp.6.0。要使用MSXM ...
  • Html基礎一--思想 主要思想,主要思想很重要 一、Html是什麼 一種標記語言(用標簽進行標記) 對要顯示的文字進行標記 二、Html核心 標簽(只認標簽) 封裝,所以必須有頭尾,你才知道標簽的範圍,你才知道那部分文字需要這個標簽。 三、Html部分 頭:各種輔助屬性信息,以及應該說是標題和摘要 ...
  • 1、安裝nodejs 2、更新npm到最新版本 3、npm配置為淘寶鏡像 4、創建項目目錄,如 ,並切換到目錄下 5、創建package.json文件,全部使用預設值,創建後可根據實際情況修改 6、搭建webpack、react、typescript需要使用的庫或插件 7、安裝visual stud ...
  • GIF圖有點大,網速慢的或將稍等片刻或可瀏覽本人的製作的demo。 Demo : 點擊查看 HTML: CSS: JS:( JS初始化div形態 ) ...
  • WebStorm混搭svn WebStorm混搭nodeJS 以less和uglify-js為例 如何用npm在root中下載模塊 webstorm簡單介紹 官網地址:http://www.jetbrains.com/webstorm/features/index.html 參考地址:http:// ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...