JavaScript 数组方法
JavaScript 数组的真正作用在数组方法中,包括转换、拼接、剪切、合并等方法。
把数组转换为字符串
JavaScript 方法 toString() 把数组转换为数组值(逗号分隔)的字符串:
<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数组方法</h1>
<h2>toString()</h2>
<p>toString() 方法以逗号分隔的字符串返回数组:</p>
<p id="demo">
<script>
var fruits = ["香蕉", "橘子", "苹果", "芒果"];
document.getElementById("demo").innerHTML = fruits.toString();
</script>
</body>
</html>
join() 方法也可将所有数组元素通过分隔符连接成为一个字符串。
<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数组方法</h1>
<h2>join()</h2>
<p>join() 方法将数组元素连接成一个字符串。</p>
<p>在这个例子中我们使用“*”作为元素之间的分隔符:</p>
<p id="demo">
<script>
var fruits = ["香蕉", "橘子", "苹果", "芒果"];
document.getElementById("demo").innerHTML = fruits.join(" * ");
</script>
</body>
</html>
Popping 和 Pushing
在处理数组时,删除元素和添加新元素是很简单的。
Popping 和 Pushing 指的是:从数组中取出,或向数组推入元素。
Popping
pop() 方法从数组中取出并删除最后一个元素:
<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数组方法</h1>
<h2>pop()</h2>
<p>pop() 方法从数组中取出并删除最后一个元素。</p>
<p>pop() 方法的返回值是已删除的项目。</p>
<p id="demo1">
<p id="demo2">
<p id="demo3">
<script>
var fruits = ["香蕉", "橘子", "苹果", "芒果"];
document.getElementById("demo1").innerHTML = fruits;
document.getElementById("demo2").innerHTML = fruits.pop();
document.getElementById("demo3").innerHTML = fruits;
</script>
</body>
</html>
Pushing
push() 方法(在数组结尾处)向数组添加一个新的元素:
<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数组方法</h1>
<h2>push()</h2>
<p>push() 方法将新元素追加到数组的最后一个位置。</p>
<button onclick="myFunction()">试一试</button>
<p id="demo">
<script>
var fruits = ["香蕉", "橘子", "苹果", "芒果"];
document.getElementById("demo").innerHTML = fruits;
function myFunction() {
fruits.push("西瓜");
document.getElementById("demo").innerHTML = fruits;
}
</script>
</body>
</html>
位移元素方法
shift() 位移与 Pop() 等同,但是处理首个元素而不是最后一个。
shift() 方法会删除首个数组元素,并把所有其他元素依次“位移”到更前的索引。
<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数组方法</h1>
<h2>shift()</h2>
<p>shift() 方法删除数组的第一个元素(并将所有其他元素“移位”到左侧),并返回位移元素:</p>
<p id="demo1">
<p id="demo2">
<p id="demo3">
<script>
var fruits = ["香蕉", "橘子", "苹果", "芒果"];
document.getElementById("demo1").innerHTML = fruits;
document.getElementById("demo2").innerHTML = fruits.shift();
document.getElementById("demo3").innerHTML = fruits;
</script>
</body>
</html>
unshift() 方法(在开头)向数组添加新元素,并“反向位移”旧元素:
<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数组方法</h1>
<h2>unshift()</h2>
<p>unshift() 方法将新元素添加到数组的开头。</p>
<button onclick="myFunction()">试一试</button>
<p id="demo">
<script>
var fruits = ["香蕉", "橘子", "苹果", "芒果"];
document.getElementById("demo").innerHTML = fruits;
function myFunction() {
fruits.unshift("柠檬");
document.getElementById("demo").innerHTML = fruits;
}
</script>
</body>
</html>
通过索引号来追加和更改元素
数组索引(下标)以 0 开始。[0] 是第一个数组元素,[1] 是第二个,[2] 是第三个 …
<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数组方法</h1>
<p>使用索引号访问数组元素:</p>
<p id="demo1">
<p id="demo2">
<script>
var fruits = ["香蕉", "橘子", "苹果", "芒果"];
document.getElementById("demo1").innerHTML = fruits;
fruits[0] = "柠檬";
document.getElementById("demo2").innerHTML = fruits;
</script>
</body>
</html>
length 属性提供了向数组追加新元素的简易方法:
<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数组方法</h1>
<p>length 属性提供了一种在不使用 push() 方法的情况下将新元素附加到数组的简便方法。</p>
<button onclick="myFunction()">试一试</button>
<p id="demo">
<script>
var fruits = ["香蕉", "橘子", "苹果", "芒果"];
document.getElementById("demo").innerHTML = fruits;
function myFunction() {
fruits[fruits.length] = "柠檬";
document.getElementById("demo").innerHTML = fruits;
}
</script>
</body>
</html>
删除元素
既然 JavaScript 数组属于对象,其中的元素就可以使用 JavaScript delete 运算符来删除:
<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数组方法</h1>
<p>删除元素会在数组中留下未定义的孔。</p>
<p id="demo1">
<p id="demo2">
<script>
var fruits = ["香蕉", "橘子", "苹果", "芒果"];
document.getElementById("demo1").innerHTML =
"第一种水果是:" + fruits[0];
delete fruits[0];
document.getElementById("demo2").innerHTML =
"第一种水果是:" + fruits[0];
</script>
</body>
</html>
使用 delete 会在数组留下未定义的空洞。所以请使用 pop() 或 shift() 取而代之。
拼接数组
splice() 方法可用于向数组添加新项:
<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数组方法</h1>
<h2>splice()</h2>
<p>splice() 方法将新元素添加到数组中。</p>
<button onclick="myFunction()">试一试</button>
<p id="demo1">
<p id="demo2">
<p id="demo3">
<script>
var fruits = ["香蕉", "橘子", "苹果", "芒果"];
document.getElementById("demo1").innerHTML = "原数组:<br>" + fruits;
function myFunction() {
var removed = fruits.splice(2, 0, "柠檬", "西瓜");
document.getElementById("demo2").innerHTML = "新数组:<br>" + fruits;
document.getElementById("demo3").innerHTML = "已删除项:<br> " + removed;
}
</script>
</body>
</html>
第一个参数(2)定义了应添加新元素的位置(拼接)。
第二个参数(0)定义应删除多少元素。
其余参数(“柠檬”,“西瓜”)定义要添加的新元素。
removed 则接受到 splice() 方法返回一个包含已删除项的数组:
使用 splice() 来删除元素
通过参数设定,您能够使用 splice() 在数组中不留“空洞”的情况下移除元素:
<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数组方法</h1>
<h2>splice()</h2>
<p>splice() 方法可用于删除数组元素。</p>
<button onclick="myFunction()">试一试</button>
<p id="demo">
<script>
var fruits = ["香蕉", "橘子", "苹果", "芒果"];
document.getElementById("demo").innerHTML = fruits;
function myFunction() {
fruits.splice(0, 1);
document.getElementById("demo").innerHTML = fruits;
}
</script>
</body>
</html>
第一个参数(0)定义新元素应该被添加(接入)的位置。
第二个参数(1)定义应该删除多个元素。
其余参数被省略。没有新元素将被添加。
合并(连接)数组
concat() 方法通过合并(连接)现有数组来创建一个新数组:
<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数组方法</h1>
<h2>concat()</h2>
<p>concat() 方法用于合并(连接)数组:</p>
<p id="demo">
<script>
var myGirls = ["Emma", "Isabella"];
var myBoys = ["Jacob", "Michael", "Ethan"];
var myChildren = myGirls.concat(myBoys);
document.getElementById("demo").innerHTML = myChildren;
</script>
</body>
</html>
concat() 方法不会更改现有数组。它总是返回一个新数组。
concat() 方法可以使用任意数量的数组参数:
<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数组方法</h1>
<h2>concat()</h2>
<p>concat() 方法用于合并(连接)数组:</p>
<p id="demo">
<script>
var arr1 = ["Emma", "Isabella"];
var arr2 = ["Jacob", "Michael", "Ethan"];
var arr3 = ["Joshua", "Daniel"];
var myChildren = arr1.concat(arr2, arr3);
document.getElementById("demo").innerHTML = myChildren;
</script>
</body>
</html>
concat() 方法也可以将值作为参数,与数组直接合并:
<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数组方法</h1>
<h2>concat()</h2>
<p>concat() 方法也可以将值合并到数组:</p>
<p id="demo">
<script>
var arr1 = ["Emma", "Isabella"];
var myChildren = arr1.concat(["Jacob", "Michael", "Ethan"]);
document.getElementById("demo").innerHTML = myChildren;
</script>
</body>
</html>
剪切数组
slice() 方法用数组的某个片段切出新数组。
本例从数组元素 1 ("Orange")开始切出一段数组:
<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数组方法</h1>
<h2>slice()</h2>
<p>此例从数组元素 1(“橘子”)开始切出数组的一部分:</p>
<p id="demo">
<script>
var fruits = ["香蕉", "橘子", "柠檬", "苹果", "芒果"];
var citrus = fruits.slice(1);
document.getElementById("demo").innerHTML = fruits + "<br><br>" + citrus;
</script>
</body>
</html>
slice() 方法创建新数组。它不会从源数组中删除任何元素。
本例从数组元素 3 ("Apple")开始切出一段数组:
<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数组方法</h1>
<h2>slice()</h2>
<p>此例从数组元素 3(“Apple”)开始切出数组的一部分:</p>
<p id="demo">
<script>
var fruits = ["香蕉", "橘子", "柠檬", "苹果", "芒果"];
var citrus = fruits.slice(3);
document.getElementById("demo").innerHTML = fruits + "<br><br>" + citrus;
</script>
</body>
</html>
slice() 可接受两个参数,比如 (1, 3)。
该方法会从开始参数选取元素,直到结束参数(不包括)为止。
<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数组方法</h1>
<h2>slice()</h2>
<p>当给 slice() 方法赋予两个参数时,它从 <i>start</i> 参数中选择数组元素,直到(但不包括)<i>end</i> 参数:</p>
<p id="demo">
<script>
var fruits = ["香蕉", "橘子", "柠檬", "苹果", "芒果"];
var citrus = fruits.slice(1,3);
document.getElementById("demo").innerHTML = fruits + "<br><br>" + citrus;
</script>
</body>
</html>
如果结束参数被省略,比如第一个例子,则 slice() 会切出数组的剩余部分。
<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数组方法</h1>
<h2>slice()</h2>
<p>此例从数组元素 2(“Lemon”)开始切出数组的一部分:</p>
<p id="demo">
<script>
var fruits = ["香蕉", "橘子", "柠檬", "苹果", "芒果"];
var citrus = fruits.slice(2);
document.getElementById("demo").innerHTML = fruits + "<br><br>" + citrus;
</script>
</body>
</html>
自动 toString()
如果需要原始值,则 JavaScript 会自动把数组转换为字符串。下面例子两种方法将产生相同的结果:
<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数组方法</h1>
<h2>toString()</h2>
<p>toString() 方法以逗号分隔的字符串返回数组:</p>
<p id="demo1">
<p id="demo2">
<script>
var fruits = ["香蕉", "橘子", "柠檬", "苹果", "芒果"];
document.getElementById("demo1").innerHTML = fruits.toString();
document.getElementById("demo2").innerHTML = fruits;
</script>
</body>
</html>
所有 JavaScript 对象都拥有 toString() 方法。
完整的数组参考手册
如需完整的参考手册,请访问本站完整的 JavaScript 数组参考手册。