学习内容:forEach、slice和splice、数组的剩余方法
学习笔记
forEach
一般我们都用for循环遍历数组
JS中还为我们提供了一个方法,用来遍历数组
forEach() 只支持IE8以上的浏览器
forEach()方法需要一个函数作为参数;这种函数是由我们创建,但不是由我们调用的,称之为回调函数
语法:
arr.forEach(function(){})
数组中有几个元素,函数就执行几次,每次执行时,浏览器会将遍历到的元素以实参的形式传递进来,我们可以来定义形参读取这些内容
浏览器会在回调函数中传递三个参数;第一个参数就是当前正在遍历的元素,第二个参数就是当前正在遍历的元素的索引;第三个元素就是正在遍历的数组
实例:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script type="text/javascript">
var arr=["张三","李四","王五","李六"];
arr.forEach(function(value,index,obj){
document.write("value= "+value+"<br>");
document.write("index= "+index+"<br>");
document.write("obj= "+obj+"<br>");
});
</script>
<title></title>
</head>
<body>
</body>
</html>
结果
slice和splice
slice
slice()用来从某个数组返回某个特定的元素;
参数:
1.截取开始的位置的索引,包含开始索引
2.截取结束的位置的索引,不包含结束索引;第二个参数可以省略不写,此时会截取从开始索引往后的所有元素
索引可以传递负值,如果传递负值,则从后往前计算
-1倒数第一个,-2倒数第二个,...
语法:
arr.slice(start,end);
该方法不会改变元素数组,而是将 截取到的元素封装到一个新数组中返回
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<script type="text/javascript">
var arr=["张三","李四","王五","李六"];
var result=arr.slice(1,3);
document.write(result);
</script>
</head>
<body>
</body>
</html>
结果:
splice
splice()可以用于删除数组中的指定元素
使用splice()会影响到原数组,会将指定元素从原数组中删除,并将删除的元素作为返回值
参数:
第一个表示开始位置的索引
第二个表示删除的数量
splice()还有第三个及以后的参数,可以传递一些新的元素,这些元素会自动插入到开始位置索引前面
语法:
arr.splice(start,num,"添加的新元素",...);
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<script type="text/javascript">
var arr=["张三","李四","王五","李六"];
var result=arr.splice(1,2,"赵七","黄sir");
document.write(result+"<br>");
document.write(arr);
</script>
</head>
<body>
</body>
</html>
结果:
数组的剩余方法
concat()
concat()可以连接两个或多个数组,并将新的数组返回
该方法不会对原数组产生影响
语法
var arr =["张三","李四","王五","李六"];
var arr1=["小刘","小赵","小李"];
var result=arr.concat(arr1);
实例
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<script type="text/javascript">
var arr =["张三","李四","王五","李六"];
var arr1=["小刘","小赵","小李"];
var result=arr.concat(arr1);
document.write(result);
</script>
</head>
<body>
</body>
</html>
结果
join()
该方法可以将数组转化为一个字符串 ;该方法不会对原数组产生影响,而是将转换后的字符串作为结果返回
在join()中可以指定一个字符串作为参数,这个字符串将会成为数组中元素的连接符,如果不指定连接符,则默认使用","作为连接符
语法
var arr =["张三","李四","王五","李六"];
var result=arr.join("——");
document.write(result);
实例
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<script type="text/javascript">
var arr =["张三","李四","王五","李六"];
var result=arr.join("——");
document.write(result);
</script>
</head>
<body>
</body>
</html>
结果
reverse()
reverse()方法可以将一个数组反转(前边的去后边,后边的去前边);该方法会改变原数组
语法
var arr =["张三","李四","王五","李六"];
arr.reverse();
document.write(arr);
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<script type="text/javascript">
var arr =["张三","李四","王五","李六"];
arr.reverse();
document.write(arr);
</script>
</head>
<body>
</body>
</html>
结果
sort()
sort()可以用来对数组中的元素进行排序;也会影响原数组,默认会按照Unicode编码进行排序
var arr =["f","a","s","d","e","k"];
arr.sort();
实例
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<script type="text/javascript">
var arr =["f","a","s","d","e","k"];
arr.sort();
document.write(arr);
</script>
</head>
<body>
</body>
</html>
即使对于纯数字的数组,是使用sort()排序时,也会按照Unicode编码进行排序,所以对数字进行排序时可能会得到错误的结果;我们可以自己指定排序的规则
我们可以在sort()中添加一个回调函数,来指定排序规则,回调函数中需要定义两个形参,浏览器将会分别使用数组中的元素作为实参去调用回调函数
使用哪个元素调用不确定,但肯定的是在数组中a一定在b前边
浏览器会根据回调函数的返回值来决定元素的排序,
如果韩慧一个大于0的值,则元素会交换位置
如果返回一个小于0的值,则元素位置不变
如果返回一个0,则认为两个元素相等,也不交换位置
语法
升序:
var arr1=[5,6,8,2,4,9,1,54,36,15];
arr1.sort(function(a,b){
return a-b;
});
降序:
var arr1=[5,6,8,2,4,9,1,54,36,15];
arr1.sort(function(a,b){
return b-a;
});
升序实例
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<script type="text/javascript">
var arr1=[5,6,8,2,4,9,1,54,36,15];
arr1.sort(function(a,b){
return a-b;
});
document.write(arr1);
</script>
</head>
<body>
</body>
</html>
结果