javascript 数组方法
javascript 通过数组方法来操作数组。
1. 把数组转换为字符串
javascript 方法 tostring() 把数组转换为数组值(逗号分隔)的字符串。
范例
var fruits = ["banana", "orange", "apple", "mango"]; document.getelementbyid("demo").innerhtml = fruits.tostring();
结果
banana,orange,apple,mango
join() 方法也可将所有数组元素结合为一个字符串。
它的行为类似 tostring(),但是您还可以规定分隔符:
范例
var fruits = ["banana", "orange","apple", "mango"]; document.getelementbyid("demo").innerhtml = fruits.join(" * ");
结果
banana * orange * apple * mango
2. popping 和 pushing
在处理数组时,删除元素和添加新元素是很简单的。
popping 和 pushing 指的是:
从数组弹出项目,或向数组推入项目。
3. popping
pop() 方法从数组中删除最后一个元素:
范例
var fruits = ["banana", "orange", "apple", "mango"];
fruits.pop(); // 从 fruits 删除最后一个元素("mango")
pop() 方法返回“被弹出”的值:
范例
var fruits = ["banana", "orange", "apple", "mango"];
var x = fruits.pop(); // x 的值是 "mango"
4. pushing
push() 方法(在数组结尾处)向数组添加一个新的元素:
范例
var fruits = ["banana", "orange", "apple", "mango"];
fruits.push("kiwi"); // 向 fruits 添加一个新元素
push() 方法返回新数组的长度:
范例
var fruits = ["banana", "orange", "apple", "mango"];
var x = fruits.push("kiwi"); // x 的值是 5
5. 位移元素
位移与弹出等同,但处理首个元素而不是最后一个。
shift() 方法会删除首个数组元素,并把所有其他元素“位移”到更低的索引。
范例
var fruits = ["banana", "orange", "apple", "mango"];
fruits.shift(); // 从 fruits 删除第一个元素 "banana"
shift() 方法返回被“位移出”的字符串:
范例
var fruits = ["banana", "orange", "apple", "mango"];
fruits.shift(); // 返回 "banana"
unshift() 方法(在开头)向数组添加新元素,并“反向位移”旧元素:
范例
var fruits = ["banana", "orange", "apple", "mango"];
fruits.unshift("lemon"); // 向 fruits 添加新元素 "lemon"
unshift() 方法返回新数组的长度。
范例
var fruits = ["banana", "orange", "apple", "mango"];
fruits.unshift("lemon"); // 返回 5
6. 更改元素
通过使用它们的索引号来访问数组元素:
数组索引(下标)以 0 开始。[0] 是第一个数组元素,[1] 是第二个,[2] 是第三个 ...
范例
var fruits = ["banana", "orange", "apple", "mango"];
fruits[0] = "kiwi"; // 把 fruits 的第一个元素改为 "kiwi"
length 属性提供了向数组追加新元素的简易方法:
范例
var fruits = ["banana", "orange", "apple", "mango"];
fruits[fruits.length] = "kiwi"; // 向 fruits 追加 "kiwi"
7. 删除元素
既然 javascript 数组属于对象,其中的元素就可以使用 javascript delete 运算符来删除:
范例
var fruits = ["banana", "orange", "apple", "mango"];
delete fruits[0]; // 把 fruits 中的首个元素改为 undefined
使用 delete 会在数组留下未定义的空洞。请使用 pop() 或 shift() 取而代之。
8. 拼接数组
splice() 方法可用于向数组添加新项:
范例
var fruits = ["banana", "orange", "apple", "mango"]; fruits.splice(2, 0, "lemon", "kiwi");
第一个参数(2)定义了应添加新元素的位置(拼接)。
第二个参数(0)定义应删除多少元素。
其余参数(“lemon”,“kiwi”)定义要添加的新元素。
splice() 方法返回一个包含已删除项的数组:
范例
var fruits = ["banana", "orange", "apple", "mango"]; fruits.splice(2, 2, "lemon", "kiwi");
9. 使用 splice() 来删除元素
通过聪明的参数设定,您能够使用 splice() 在数组中不留“空洞”的情况下移除元素:
范例
var fruits = ["banana", "orange", "apple", "mango"];
fruits.splice(0, 1); // 删除 fruits 中的第一个元素
第一个参数(0)定义新元素应该被添加(接入)的位置。
第二个参数(1)定义应该删除多个元素。
其余参数被省略。没有新元素将被添加。
10. 合并(连接)数组
concat() 方法通过合并(连接)现有数组来创建一个新数组:
范例(合并两个数组)
var mygirls = ["cecilie", "lone"]; var myboys = ["emil", "tobias", "linus"]; var mychildren = mygirls.concat(myboys); // 连接 mygirls 和 myboys
concat() 方法不会更改现有数组。它总是返回一个新数组。
concat() 方法可以使用任意数量的数组参数:
范例(合并三个数组)
var arr1 = ["cecilie", "lone"]; var arr2 = ["emil", "tobias", "linus"]; var arr3 = ["robin", "morgan"]; var mychildren = arr1.concat(arr2, arr3); // 将arr1、arr2 与 arr3 连接在一起
concat() 方法也可以将值作为参数:
范例(将数组与值合并)
var arr1 = ["cecilie", "lone"]; var mychildren = arr1.concat(["emil", "tobias", "linus"]);
11. 裁剪数组
slice() 方法用数组的某个片段切出新数组。
本例从数组元素 1 ("orange")开始切出一段数组:
范例
var fruits = ["banana", "orange", "lemon", "apple", "mango"]; var citrus = fruits.slice(1);
slice() 方法创建新数组。它不会从源数组中删除任何元素。
本例从数组元素 3 ("apple")开始切出一段数组:
范例
var fruits = ["banana", "orange", "lemon", "apple", "mango"]; var citrus = fruits.slice(3);
slice() 可接受两个参数,比如 (1, 3)。
该方法会从开始参数选取元素,直到结束参数(不包括)为止。
范例
var fruits = ["banana", "orange", "lemon", "apple", "mango"]; var citrus = fruits.slice(1, 3);
如果结束参数被省略,比如第一个例子,则 slice() 会切出数组的剩余部分。
范例
var fruits = ["banana", "orange", "lemon", "apple", "mango"]; var citrus = fruits.slice(2);
12. 自动 tostring()
如果需要原始值,则 javascript 会自动把数组转换为字符串。下面两个例子将产生相同的结果:
范例
var fruits = ["banana", "orange", "apple", "mango"]; document.getelementbyid("demo").innerhtml = fruits.tostring();
范例
var fruits = ["banana", "orange", "apple", "mango"]; document.getelementbyid("demo").innerhtml = fruits;
所有 javascript 对象都拥有 tostring() 方法。
13. 数组排序
我们将在下一章学习到数组排序的知识~。
14. 查找数组中的最大和最小值
没有在 javascript 数组中查找最高和最低值的内建函数。
您将在本教程的下一章学习如何解决这个问题。