JS学习——数组方法
学习内容来源:JavaScript 数组方法
JavaScript 数组方法
把数组转换为字符串
1、JavaScript 方法 toString() 把数组转换为数组值(逗号分隔)的字符串。
注意:所有 JavaScript 对象都拥有 toString() 方法
// id 为 demo 的 html 元素的内容是 Banana,Orange,Apple,Mango
var fruits = ["Banana", "Orange", "Apple", "Mango"];
document.getElementById("demo").innerHTML = fruits.toString();
2、join() 方法也可将所有数组元素结合为一个字符串。它的行为类似 toString(),但是还可以规定分隔符。
// id 为 demo 的 html 元素的内容是 Banana * Orange * Apple * Mango
var fruits = ["Banana", "Orange","Apple", "Mango"];
document.getElementById("demo").innerHTML = fruits.join(" * ");
Popping 和 Pushing
Popping 指的是从数组弹出项目,Pushing 指的是向数组推入项目。
Popping
pop() 方法从数组中删除最后一个元素,并返回“被弹出”的值
var fruits = ["Banana", "Orange", "Apple", "Mango"];
var x = fruits.pop(); // x 的值是 "Mango"
Pushing
push() 方法在数组结尾处向数组添加一个新的元素,并返回新数组的长度
var fruits = ["Banana", "Orange", "Apple", "Mango"];
var x = fruits.push("Kiwi"); // x 的值是 5
位移元素
shift()
会删除首个数组元素,并把所有其他元素“位移”到更低的索引。
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.shift(); // 从 fruits 删除第一个元素 "Banana",并返回返回被“位移出”的字符串 "Banana"
unshift()
在开头向数组添加新元素,并“反向位移”旧元素。
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.unshift("Lemon"); // 向 fruits 添加新元素 "Lemon",并返回新数组的长度
更改元素
通过使用数组的索引号来访问数组元素。
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits[0] = "Kiwi"; // 把 fruits 的第一个元素改为 "Kiwi"
length 属性提供了向数组追加新元素的简易方法。
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits[fruits.length] = "Kiwi"; // 向 fruits 追加 "Kiwi"
删除元素
JavaScript 数组属于对象,其中的元素就可以使用 JavaScript delete 运算符来删除。
注意:使用 delete 会在数组留下未定义的空洞。
var fruits = ["Banana", "Orange", "Apple", "Mango"];
delete fruits[0]; // 把 fruits 中的首个元素改为 undefined
拼接数组
注意:使用 splice() 会改变原数组
1、使用 splice() 向数组添加新项
// 第一个参数(2)定义了应添加新元素的位置(拼接)。
// 第二个参数(2)定义应删除多少元素。
// 其余参数(“Lemon”,“Kiwi”)定义要添加的新元素。
// 最后返回一个包含已删除项的数组。
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.splice(2, 2, "Lemon", "Kiwi"); // 返回 ["Apple", "Mango"]
2、使用 splice() 来删除元素
// 第一个参数(0)定义新元素应该被添加(接入)的位置。
// 第二个参数(1)定义应该删除多个元素。
// 其余参数被省略。没有新元素将被添加。
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.splice(0, 1); // 删除 fruits 中的第一个元素 "Banana",返回 ["Banana"]
合并(连接)数组
concat() 方法通过合并(连接)现有数组来创建一个新数组。concat() 方法不会更改现有数组。它总是返回一个新数组。concat() 方法可以使用任意数量的数组参数。
1、合并两个数组
var myGirls = ["Cecilie", "Lone"];
var myBoys = ["Emil", "Tobias", "Linus"];
var myChildren = myGirls.concat(myBoys); // 连接 myGirls 和 myBoys
2、合并三个数组
var arr1 = ["Cecilie", "Lone"];
var arr2 = ["Emil", "Tobias", "Linus"];
var arr3 = ["Robin", "Morgan"];
var myChildren = arr1.concat(arr2, arr3); // 将arr1、arr2 与 arr3 连接在一起
3、将数组与值合并
var arr1 = ["Cecilie", "Lone"];
var myChildren = arr1.concat(["Emil", "Tobias", "Linus"]);
裁剪数组
slice() 方法用数组的某个片段切出新数组。会创建新数组。它不会从源数组中删除任何元素。
1、接收一个参数
从参数作为数组索引开始选取元素,直到数组结束为止。
// 从数组元素索引3 ("Apple")开始切出一段数组
var fruits = ["Banana", "Orange", "Lemon", "Apple", "Mango"];
var citrus = fruits.slice(3); // 返回 ["Apple", "Mango"]
2、接受两个参数
从第一个参数作为数组索引选取元素,直到结束参数(不包括)为止。
// 从数组元素索引3 ("Apple")开始切出一段数组
var fruits = ["Banana", "Orange", "Lemon", "Apple", "Mango"];
var citrus = fruits.slice(1, 3); // 返回 ["Orange", "Lemon"]