JavaScript数组

一. JavaScript数组

1.数组(Array):就是一组数据的集合,存储在单个变量下的优雅的方式。

2.创建数组

        1)利用new创建数组

var arr=new Array();

        这里创建的是一个空的数组。

        2)利用字面量创建数组

var arr=[];

        这里创建的也是一种空的数组。

        数组里面的数值之间可以通过逗号进行分割

var arr1=[1,2,'pink',true]

        这种声明数组并赋值,我们称之为数组的初始化,数组里面的数据,我们称之为数组元素。

3.数组的索引(下标):用来访问数组里面的元素,数组的下标从0开始;

JavaScript数组_第1张图片 

        获取数组元素的格式: console.log(数组名[索引号])

        当数组中找不到要求要输出的元素,系统输出的结果就是underfined

获取数组的小案例:定义一个数组,里面存在星期一到星期天,在控制台打印输出星期天。

// 获取数组的小案例:定义一个数组,里面存放星期一到星期天,在控制台打印输出星期天
			var arr2=['星期一','星期二','星期三','星期四','星期五','星期六','星期天']
			console.log(arr2[6])

 二. 遍历数组

        遍历数组:就是把数组的元素从头到尾访问一次(通过循环实现数组的遍历),数组的遍历通过for循环实现。

            var arr=['red','pink',1,2,3]
			for(var i= 0;i<=4; i++){
				console.log(arr[i]);
			}

JavaScript数组_第2张图片

 原因:1.因为数组索引号从0开始,所以i必须从0开始

            2. 输出的时候arr[i],其中i是当计数器进行使用的。

遍历数组的案例:请将['关羽','张飞','马超','赵云','黄忠','刘备','诸葛亮','姜维',pink];数组里的元素依次打印到控制台.

        // 请将['关羽','张飞','马超','赵云','黄忠','刘备','诸葛亮','姜维',pink];数组里的元素依次打印到控制台.
		
		var arr1=['关羽','张飞','马超','赵云','黄忠','刘备','诸葛亮','姜维','pink']
		for(var i =0;i<=7;i++)	{
			console.log(arr1[i]);
		}
			
		// 数组的长度	可以通过   数组名.length 获取数组的长度
			console.log(arr1.length);
			for(var i=0; i

JavaScript数组_第3张图片

       注意点:   数组的长度是元素的个数,不要跟索引号进行混淆

                        arr.length  动态检测数组元素的个数

数组的案例:

1.数组求和及平均值,求数组[2,6,1,7,4]里面的所有元素和及平均值。

            var sum=0;
			var average=0;
			var arr=[2,6,1,7,4]
			for(var i=0 ;i 

2.数组中的最大值,求数组[2,6,1,77,52,34,8,2,44,66]中的最大值。

            var arr=[2,6,1,77,52,34,8,2,44,66]
			var max=arr[0];
			for(var i=1 ; imax){
					max=arr[i];
				}
			}
			console.log('该数组的最大值是'+max)

3.求数组中的最小值,求数组[98,6,1,77,52,34,8,2,44,66,90]中的最小值。

            var arr=[98,6,1,77,52,34,8,2,44,66,90]
			var min=arr[0];
			for(var i=1; i

4.数组转换为分割字符,将数组['red','green','blue','pink']转换为字符串,并且用|或其他符号进行分割,(字符串之间的相加就是简单意义上面的拼接)。

            var arr=['red','green','blue','pink'];
			var str ='';
			for (var i=0 ; i< arr.length ; i++){
				str += arr[i] + '|';
			}
			console.log(str);

这种方法只能使用  |  来进行符号的分割,下面这种方法是直接声明一个变量,将所有更改的符号放在里面,后续更改项目符号,就可以实现字符串之间进行分割。

            var arr=['red','green','blue','pink'];
			var str ='';
			var sep ='*';
			// 直接声明一个变量,将所有更改的符号放在里面,后续更改项目符号,就可以实现字符串之间进行分割
			for (var i=0 ; i< arr.length ; i++){
				str += arr[i] + sep;
			}
			console.log(str);

 三.新增数组元素

1.通过修改数组的长度,新增数组的元素

            var arr = ['red','pink','green'];
			console.log(arr.length);
			arr.length = 5 ;
			// 我们把数组的长度修改为5,数组里面就应该有5个元素
			console.log(arr);

  由于对数组进行了扩容,并没有对数组的元素进行添加,所以当输出数组中的没有被定义值的时候,输出的就是underfined。

2.新增数组元素,通过索引号的方式增加数组元素(修改索引号,增加数组元素)

            var arr1 = ['red','green','blue'];
			arr1[3] = 'pink';
			console.log(arr1);
			arr1[4] = 'yellow';
			console.log(arr1);
			arr1[2] = 'white';
			console.log(arr1);

         当输入的索引号被占有,追加的数组元素,就会替换之间的数组元素,输入的索引号没有元素进行占有,就会自动添加数组元素。

数组中新增数组元素:新建一个数组,里面存放1-10。

            var arr2 = [];
			// 声明空数组的时候直接使用[],不需要添加其他的东西
			for(var i =0 ;i<10; i++){
				// arr = i
				// 不能直接对数组进行赋值
				arr2[i] = i+1;
			}
			console.log(arr2)

 

数组的筛选案例:将数组[2,0,6,1,77,56,64,12,9,8,6,88]中大于等于10的元素选出来,放入新的数组当中

数组的筛选  方法一:

            var arr =[2,0,6,1,77,56,64,12,9,8,6,88];
			var newarr=[];
			var j=0;
			for(var i=0 ;i10){
					// 新数组应该从0 开始  ,然后存入元素,索引号开始递增
					newarr[j]=arr[i];
					j++
				}
			}
			console.log(newarr);

 数组的筛选 方法二:

            var arr =[2,0,6,1,77,56,64,12,9,8,6,88];
			var newArr=[];
			newArr.length;
			// 数组没有存入元素的时候,该数组的长度就为0,当存入元素之后,数组的长度就会默认进行加1的操作
			for(var i=0 ;i10){
					// 新数组应该从0 开始  ,然后存入元素,索引号开始递增
					newArr[newArr.length]=arr[i];
				}
			}
			console.log(newArr)

 

数组的总结性案例:

1.删除数组中指定的数组元素:要求将数组[2,0,6,77,53,54,0,23,65,9]中的0去掉后,形成一个不包含0的新数组

            var arr=[2,0,6,77,53,54,0,23,65,9];
			var newArr=[];
			for(var i=0;i

 

2.要求:将数组['关羽','张飞','马超','赵云','黄忠','刘备','诸葛亮','姜维']的内容反过来存放,最后打印输出的是['姜维', '诸葛亮', '刘备', '黄忠', '赵云', '马超', '张飞', '关羽']

            var arr=['关羽','张飞','马超','赵云','黄忠','刘备','诸葛亮','姜维'];
			var newArr=[];
			for(var i = arr.length - 1 ; i>=0 ; i--){
				newArr[newArr.length]=arr[i]
			}
			console.log(newArr);

3.冒泡排序(升序)冒泡排序是一种算法,把一系列的数据按照一定的顺序进行排列显示。 

            var arr=[1,2,33,44,55,66,88,12,54,76];
			// 外层循环管躺数
			for(var i = 0 ; i <= arr.length - 1; i++){
				// 里面的循环管每一躺的交换次数
				for (var j = 0 ; j <= arr.length-i-1 ; j++){
					// 内部交换两个变量的值,前一个和后面一个数组元素相比较
					if( arr[j] > arr[j + 1]){
						var temp = arr[j];
						arr[j] = arr[j + 1];
						arr[j + 1 ]= temp;
					}
				}
			}
			console.log(arr);

        冒泡排序(降序排序)

            var arr=[1,2,33,44,55,66,88,12,54,76];
			// 外层循环管躺数
			for(var i = 0 ; i <= arr.length - 1; i++){
				// 里面的循环管每一躺的交换次数
				for (var j = 0 ; j <= arr.length-i-1 ; j++){
					// 内部交换两个变量的值,前一个和后面一个数组元素相比较
					if( arr[j] < arr[j + 1]){
						var temp = arr[j];
						arr[j] = arr[j + 1];
						arr[j + 1 ]= temp;
					}
				}
			}
			console.log(arr);

 

你可能感兴趣的:(javascript,前端)