JavaScript学习笔记(四)

Posted by Ivens on October 29, 2019

一.JavaScript 数组

①访问完整数组

通过 JavaScript,可通过引用数组名来访问完整数组:

1
2
var cars = ["Saab", "Volvo", "BMW"];
document.getElementById("demo").innerHTML = cars; 

②可以使用 Array.foreach() 函数遍历数组元素

1
2
3
4
5
6
7
8
9
10
var fruits, text;
fruits = ["Banana", "Orange", "Apple", "Mango"];

text = "<ul>";
fruits.forEach(myFunction);
text += "</ul>";

function myFunction(value) {
  text += "<li>" + value + "</li>";
}

③添加数组元素

  • 最佳方法是使用 push() 方法
    1
    2
    
    var fruits = ["Banana", "Orange", "Apple", "Mango"];
    fruits.push("Lemon");                // 向 fruits 添加一个新元素 (Lemon)
    
  • 也可以使用 length 属性向数组添加新元素
    1
    2
    
    var fruits = ["Banana", "Orange", "Apple", "Mango"];
    fruits[fruits.length] = "Lemon";     // 向 fruits 添加一个新元素 (Lemon)
    

    注意:避免 new Array(),没有必要使用 JavaScript 的内建数组构造器 new Array()。请使用 [ ] 取而代之!

二.JavaScript 数组方法

JavaScript 数组的力量隐藏在数组方法中。

1.toString() 把数组转换为数组值(逗号分隔)的字符串。

2.join() 方法也可将所有数组元素结合为一个字符串。它的行为类似 toString(),但是您还可以规定分隔符:

1
2
var fruits = ["Banana", "Orange","Apple", "Mango"];
document.getElementById("demo").innerHTML = fruits.join(" * "); 

3.Pop()Push()指的是:从数组弹出项目,或向数组推入项目。 使用 delete() 会在数组留下未定义的空洞。请使用 pop() 或 shift() 取而代之。

4.shift() 方法会删除首个数组元素,并把所有其他元素“位移”到更低的索引。shift() 方法返回被“位移出”的字符串.

5.unshift() 方法(在开头)向数组添加新元素,并“反向位移”旧元素,unshift() 方法返回新数组的长度。

1
2
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.unshift("Lemon");    // 向 fruits 添加新元素 "Lemon"

6.splice() 方法可用于向数组添加新项:

1
2
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.splice(2, 0, "Lemon", "Kiwi");  //结果:Banana, Orange,Lemon, Kiwi Apple, Mango

第一个参数(2)定义了应添加新元素的位置(拼接)。

第二个参数(0)定义应删除多少元素。

其余参数(“Lemon”,“Kiwi”)定义要添加的新元素。

splice() 方法返回一个包含已删除项的数组.

7.使用 splice() 在数组中不留“空洞”的情况下移除元素

1
fruits.splice(0, 1);        // 删除 fruits 中的第一个元素

8.concat() 方法通过合并(连接)现有数组来创建一个新数组

concat() 方法不会更改现有数组。它总是返回一个新数组。

concat() 方法可以使用任意数量的数组参数:

1
2
3
var myGirls = ["Cecilie", "Lone"];
var myBoys = ["Emil", "Tobias", "Linus"];
var myChildren = myGirls.concat(myBoys);   // 连接 myGirls 和 myBoys

9.slice() 方法用数组的某个片段切出新数组。它不会从源数组中删除任何元素。

1
2
var fruits = ["Banana", "Orange", "Lemon", "Apple", "Mango"];
var citrus = fruits.slice(1);    //从数组元素 1 ("Orange")开始切出一段数组:Orange,Lemon,Apple,Mango

slice() 可接受两个参数,比如 (1, 3)。

该方法会从开始参数选取元素,直到结束参数(不包括)为止。

三.JavaScript 数组排序(复杂)

1.sort() 方法以字母顺序对数组进行排序

2.reverse() 方法反转数组中的元素,可以使用它以降序对数组进行排序

3.比值函数

1
function(a, b){return a-b}

四.JavaScript 数组迭代方法

forEach()函数遍历数组元素

该函数接受 3 个参数(后同):

  • 项目值
  • 项目索引
  • 数组本身

用法(在forEach中再新建方法,传参即可):

1
2
3
4
var array1 = [1,22,34,45,67];
array1.forEach(function (value,index){
    alert(""+index+"个位置是:"+value);
})

Array.map()方法通过对每个数组元素执行函数来创建新数组。 如:

1
2
3
4
5
6
7
// 这个例子将每个数组值乘以2:
var numbers1 = [45, 4, 9, 16, 25];
var numbers2 = numbers1.map(myFunction);

function myFunction(value, index, array) {
  return value * 2;
}

Array.filter()方法创建一个包含通过测试的数组元素的新数组。

1
2
3
4
5
6
7
// 这个例子用值大于 18 的元素创建一个新数组:
var numbers = [45, 4, 9, 16, 25];
var over18 = numbers.filter(myFunction);

function myFunction(value, index, array) {
  return value > 18;
}

Array.every()方法检查所有数组值是否通过测试。

1
2
3
4
5
6
7
// 这个例子检查所有数组值是否大于 18:
var numbers = [45, 4, 9, 16, 25];
var allOver18 = numbers.every(myFunction);

function myFunction(value, index, array) {
  return value > 18;       //返回结果为:false
}

⑤和every()对应的Array.some()方法检查某些数组值是否通过了测试。

1
2
3
4
5
6
7
// 这个例子检查某些数组值是否大于 18:
var numbers = [45, 4, 9, 16, 25];
var someOver18 = numbers.some(myFunction);

function myFunction(value, index, array) {
  return value > 18;        //返回结果为:true
}

Array.indexOf()方法在数组中搜索元素值并返回其位置。Array.lastIndexOf() 与 Array.indexOf() 类似,但是从数组结尾开始搜索。

1
2
var fruits = ["Apple", "Orange", "Apple", "Mango"];
var a = fruits.indexOf("Apple");        //结果为:0
1
2
var fruits = ["Apple", "Orange", "Apple", "Mango"];
var a = fruits.lastIndexOf("Apple");    //结果为:2

Array.find()方法返回通过测试函数的第一个数组元素的值。Array.findIndex()方法返回通过测试函数的第一个数组元素的索引。

1
2
3
4
5
6
7
// 这个例子查找(返回)大于 18 的第一个元素的值:
var numbers = [4, 9, 16, 25, 29];
var first = numbers.find(myFunction);

function myFunction(value, index, array) {
  return value > 18;
}