数组
数组的声明
下面的例子声明了一个 number 类型的数组:
let a: number[] = [1, 2, 3]
console.log(a)
// 等价的声明, 使用泛型👇
let a: Array<number> = [1, 2, 3]
console.log(a)
如果拿掉类型指定,并在数组中额外加入 'a'
元素,产生的效果如下:
let a = [1, 2, 3, 'a']
console.log(a)
[LOG]: [1, 2, 3, "a"]
a 的类型为:
获取数组的长度
使用a.length
获取 a 的长度。使用常规的方括号数组下标访问来对数组当中某个元素进行访问。如果下标越界,将会报出 undefined,而不会中断程序。
遍历数组当中的元素:
for(let i = 0; i < a.length; i ++) {
console.log(a[i])
}
判断数组是否为空:
let a = []
上述代码会报错,因为空数组必须显式地给出类型,因为编译器无法通过数组当中的数据推断类型。
if(a.length !== 0) {
console.log('a is not empty')
} else {
console.log('a is empty')
}
必须根据数组的长度来判断数组是否为空,而不是直接将数组本身作为判断的条件。
向数组当中添加/删除元素
使用 push 来从数组的尾部追加元素。
let a: number[] = []
a.push(1)
a.push(2)
a.push(3)
console.log(a)
// 输出为👇
[LOG]: [1, 2, 3]
使用 pop 来从数组尾部删除元素。
a.push(1)
a.push(2)
a.push(3)
console.log(a)
a.pop()
a.push(4)
console.log(a)
// output
[LOG]: [1, 2, 4]
使用 shift 和 unshift 来从数组前端删除或添加元素,unshift 用于从前端添加元素,而 shift 则从前端删除元素:
let a: number[] = []
a.push(1)
a.push(2)
a.push(3)
console.log(a)
a.pop()
a.push(4)
console.log(a)
a.unshift(1)
a.unshift(2)
a.unshift(3)
console.log(a)
// output
[LOG]: [3, 2, 1, 1, 2, 4]
需要注意的是,在 TypeScript 和 JavaScript 当中可以将数组类型声明为 const。此时这个数组本身仍然可以进行元素的增加和删除,但是不能将另一个数组赋值给这个数组(和 C++ 当中的常量指针概念非常的类似,即指针本身指向的地址是一个常量,不可以改变,但指针所指向的对象本身是可以改变的)。
slice
现在我们希望从数组当中取出一部分数据,具体实施方案如下:
const a = [1, 2, 3, 4, 5, 6, 7]
console.log(a.slice(2, 5), a.slice(2))
// output 👇
[LOG]: [3, 4, 5], [3, 4, 5, 6, 7]
数组还有一个名为 splice 的方法,最基础的它有两个参数,第一个参数给出从第几个元素开始(0是起点),删除几个元素:
const a = [1, 2, 3, 4, 5, 6, 7]
a.splice(3, 2)
console.log(a)
// output 👇
[LOG]: [1, 2, 3, 6, 7]
splice 还可以有很多参数,比如在挖掉的部分填写新的元素:
const a = [1, 2, 3, 4, 5, 6, 7]
a.splice(3, 2, 10, 11, 12)
console.log(a)
// output
[LOG]: [1, 2, 3, 10, 11, 12, 6, 7]
在数组当中查找元素
最简单的方法是使用 indexOf:
const a = [1, 2, 3, 4, 5, 6, 7]
a.splice(3, 2, 10, 11, 12, 13, 14, 15)
console.log(a.indexOf(2))
// out
[LOG]: 1
如果数组当中包含多个重复的元素,那么 indexOf 方法只会返回第一个元素。
indexOf 方法还有第二个参数,即从哪个位置开始查找。
lastIndexOf 可以从后向前找。
学习函数式编程后,我们将看到更丰富的查找方式。
排序
简单地调用 sort 方法无法得到我们想要的排序结果,其结果是按照字典序排列的:
const a = [1, 2, 3, 4, 5, 6, 7]
a.splice(3, 2, 10, 11, 12, 13, 14, 15)
console.log(a.sort())
// out
[LOG]: [1, 10, 11, 12, 13, 14, 15, 2, 3, 6, 7]
学习函数式编程后,我们会给 sort 传递一个函数来使它正确地对 number 数组排序。
元组 tuple
TypeScript 中,数组可以直接当作元组使用。
const a = [1, 2, 3]
const [a1, a2] = a
console.log(a1, a2)
// out
[LOG]: 1, 2
我们可以继续加入 a3、a4 等,越界的部分将会使用 undefined 填充。
split/join
split:
console.log('a, b, c, 1, 2, 3'.split(', '))
// out
[LOG]: ["a", "b", "c", "1", "2", "3"]
join:
const s = [1, 2, 3, 4].join(' ')
console.log(s)
// out
[LOG]: "1 2 3 4"