JS数组基础学习

学习内容: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>

结果

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值