关于javascript:JavaScript-数组的力量隐藏在数组方法中

33次阅读

共计 3630 个字符,预计需要花费 10 分钟才能阅读完成。

把数组转换为字符串

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

Popping 和 Pushing

在解决数组时,删除元素和增加新元素是很简略的。

Popping 和 Pushing 指的是:

从数组_弹出_我的项目,或向数组_推入_我的项目。

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"

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

位移元素

位移与弹出等同,但解决首个元素而不是最初一个。

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

更改元素

通过应用它们的_索引号_来拜访数组元素:

数组_索引(下标)_以 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"

删除元素

既然 JavaScript 数组属于对象,其中的元素就能够应用 JavaScript delete 运算符来_删除_:

实例

var fruits = ["Banana", "Orange", "Apple", "Mango"];
delete fruits[0];           // 把 fruits 中的首个元素改为 undefined

应用 delete 会在数组留下未定义的空洞。请应用 pop() 或 shift() 取而代之。

拼接数组

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");

应用 splice() 来删除元素

通过聪慧的参数设定,您可能应用 splice() 在数组中不留“空洞”的状况下移除元素:

实例

var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.splice(0, 1);        // 删除 fruits 中的第一个元素 

第一个参数(0)定义新元素应该被_增加_(接入)的地位。

第二个参数(1)定义应该_删除多个_元素。

其余参数被省略。没有新元素将被增加。

合并(连贯)数组

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"]);

裁剪数组

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);

主动 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() 办法。

正文完
 0