首页 > 其他分享 >11月13数组以及数组常用发法

11月13数组以及数组常用发法

时间:2023-11-14 09:46:04浏览次数:34  
标签:11 13 console log 元素 数组 var 方法

目录

1.数组

数组的作用:使用单独的变量名来存储一系列的值。类似于python中的列表。

简单的数组操作

var a = [123, "ABC"];
console.log(a[1]);
// 输出"ABC"

2.数据的常用方法

方法 说明
.length 数组的大小
.push(ele) 尾部追加元素
.pop() 获取尾部的元素
.unshift(ele) 头部插入元素
.shift() 头部移除元素
.slice(start,end) 切片
.reverse() 反转
.join(seq) 将数组元素连接成字符串
.concat(val,…) 连接数组
.sort() 排序
.forEach() 将数组的每个元素传递给回调函数
.splice() 删除元素,并向数组添加新元素
.map() 返回一个数组元素调用函数处理后的值的新数组

1.length方法

此方法用于查看数组的大小

例子代码

var a = ["a","b","c"];
console.log(a.length)

结果如图

2.push方法

此方法可以在尾部追加元素

例子代码

var a = ["a","b","c"];
a.push("junwan");
console.log(a);

结果如图

3.pop方法

此方法可以获取尾部的元素,但是数组会失去这个被获取的元素

例子代码

var a = ["a","b","c"];
a.push("junwan");
console.log(a.pop());
console.log(a)

结果如图

这里的结果说明了js的pop方法获取到数组尾部的数据后会将其从数组中取走,然后再次输出数组就会少去这个被pop方法获取的数据。

4.unshift方法

头部插入元素

例子代码

var a = ["a","b","c"];
a.unshift("junwan");
console.log(a);

效果如图

5.shift方法

此方法可以移除头部的元素

例子代码

var a = ["a","b","c"];
a.unshift("junwan");
a.shift();
console.log(a);

效果如图

6.slice方法

此方法就是切片的效果

var a = ["a","b","c"];
a.unshift("junwan");
console.log(a.slice(0,2));

效果如图

7.reverse方法

此方法可以让数组内的元素进行反转

例子代码

var a = ["a","b","c"];
a.unshift("junwan");
a.reverse()
console.log(a);

效果如图

8.join方法

此方法能将数组元素连接成字符串,同时也可以选择用什么符号进行连接

普通例子代码

var a = ["a","b","c"];
a.unshift("junwan");
console.log(a)
console.log(a.join());

效果如图

选择符号进行连接例子代码

var a = ["a","b","c"];
a.unshift("junwan");
console.log(a)
console.log(a.join("|"));
console.log(a.join("天"));
console.log(a.join("ziyue"));

效果如图

9.concat方法

此方法用于将多个数组之间进行连接

例子代码

var a = ["a","b","c"];
var b = ["lzy","sjw","wmc"];
a.concat(b)
console.log(a.concat(b));

效果如图

10.sort方法

此方法用于排序

例子代码

var a = ["c","d","b","a"];
console.log(a.sort())

效果如图

特殊情况

然后就是特殊的情况,就是当数组内都是数字时,有可能排序会有问题

例子情况

var numbers = [1, 10, 21, 2];
numbers.sort();
console.log(numbers); // 输出:[1, 10, 2, 21]

效果如图

解决特殊情况的方法

出现这种情况就需要使用比较函数function来处理

升序:

首先是升序的排序格式(可以理解为比大小)它的顺序是从小到大

var numbers = [1,10,21,2];
numbers.sort(function(a,b){
    return a - b;
});
console.log(numbers);

这里通过将function里面的a和b进行比较,

可以这么理解如果a-b结果为负值,表示a应该排在b之前。

如果结果为零,表示a和b相等。

如果结果为正值,表示a应该排在b之后。

效果如图

降序:

然后就是降序的排序格式(也是比大小)它的顺序是从大到小。

格式

var numbers = [1,10,21,2];
numbers.sort(function(a,b){
    return b - a;
});
console.log(numbers);

这个代码里面只是将a - b换成了b - a

这意味着,如果b - a 的结果为正值,那么b应该排在a之前;

如果结果为零,表示a和b相等;

如果结果为负值,表示b应该排在a之后。

效果如图

11.forEach方法

此方法用于将数组的每个元素传递给回调函数。

格式

forEach(function(currentValue, index, array), thisValue)

首先是参数function:它是必需的,每个元素需要调用的函数。

然后就是function里面的参数

参数 描述
currentValue 必需,当前数组元素的值。
index 可选,当前元素的索引值。
array 可选,代表当前使用forEach方法的数组的名字(这里的array是一个例子,实际应用是要填调用此方法数组的名称)

例子代码如下

var fruits = ["apple", "banana", "orange"];
fruits.forEach(function(fruit, index, fruits){
    console.log(index,fruit, fruits)
})

效果如图

在此代码里面fruit代表了fruits数组里面的元素,然后index如果不改就会以默认的形式将该数组的元素索引给获取出来。然后就是fruits是将这个数组带入然后每次迭代它都输出(可以使用也可以不使用,个人需求)。

12.splice方法

此方法用于删除元素,并向数组添加新元素

格式

splice(start,deleteCount,item1,.....,itemX)

然后就是它的内部参数

参数 描述
start 必需。规定从何处添加/删除元素。
该参数是开始插入和三处的数组元素的下标,必须是数字。
deleteCount 必需。规定应该删除多少元素。必须是数字,但可以是"0"。如果未规定此参数,则删除从index开始到原数组结尾的所有元素。
item1,…,itemX 可选。要添加到数组的元素(可选)。

将删除的功能演示一下

代码

var fruits = ["apple", "banana", "orange", "grape"];
fruits.splice(1, 2);
console.log(fruits);

这里让splice从索引位置为1开始删除,然后2是决定删除多少个元素。

效果如图

然后这里将插入的功能也给进行实现

代码

var fruits = ["apple", "banana", "orange", "grape"];
fruits.splice(1, 2,"junwan","xile","songli");
console.log(fruits);

效果如图

在这个代码里面先从索引为1的位置开始删除然后再从删除的地方进行插入新的数据。

13.map方法

用于创建一个新数组,其中的每个元素都是原始数组中的对应元素调用提供的函数后的结果(就是在原数组的元素内进行一定的处理重新创建一个数组给添加进去)。

基本格式

array.map(function(currentValue, index, array) {
  // 处理每个元素的逻辑
  // 返回新的元素
});

function的参数

参数 描述
currentValue 必需的参数,表示当前数组内的元素。
index 可选,当前元素的索引值
array 可选,表示当前调用此方法的数组。

实例代码

var arr = ["123", "a", "b", "c", "d"];

var arr1 = arr.map(function(val, index, arr){
    return val + 1
})

console.log(arr1)

在此函数中index和arr没有什么特殊的体现(有些鸡肋可有可无)

效果如图

还有用for循环取值

格式如下

var brr = ["123","456","789","10111213"];
for(var i = 0; i<brr.length;i++){
    console.log(brr[i])
}

在这个for循环里面循环起始条件是i等于0,循环条件是i小于数组brr的长度,每次循环结束后i自增。console.log(brr[i])在每次循环中,使用console.log输出数组brr在索引i处的元素。

还有一个简写的形式

for(i in brr){
    console.log(brr[i])
}

然后就是效果图

标签:11,13,console,log,元素,数组,var,方法
From: https://www.cnblogs.com/slzjb/p/17830928.html

相关文章

  • 11.14每日总结
    今天早上课上进行了大型数据库的实验二1.实验目的(1)理解HDFS在Hadoop体系结构中的角色;(2)熟练使用HDFS操作常用的Shell命令;(3)熟悉HDFS操作常用的JavaAPI。2.实验平台(1)操作系统:Linux(建议Ubuntu16.04或Ubuntu18.04);(2)Hadoop版本:3.1.3;(3)JDK版本:1.8;(4)JavaIDE:Eclipse。3.实验步骤......
  • 20231114学习总结
    推荐参考书:[1]范淼,李超.Python机器学习及实践,清华大学出版社.[2]PeterHarrington.机器学习实战,人民邮电出版社。《机器学习B实验任务书1》一、上机安排时间地点第10周周一2023.11.06第6-7节九实4-3、4-4第11周周一2023.11.13第6-7节九实......
  • 2023年11月13日模拟赛
    同步更新于我的博客总结昨日中二病发作写了一篇离谱文章,请直接无视,别看阿⁄(⁄⁄•⁄ω⁄•⁄⁄)⁄。害怕......
  • (链表)11-链表相加
      1importjava.util.*;23/*4*publicclassListNode{5*intval;6*ListNodenext=null;7*}8*/910publicclassSolution{11/**12*13*@paramhead1ListNode类14*@paramhead2ListNode类15......
  • 11.13 模拟赛小记
    30+0+10+0全真模拟。今天的模拟赛有一种格外的说不上来的绝望的感觉。很不好描述的。一直在想如果这是真实的noip赛场那我不就大寄特寄了。下午因为不舒服所以玩了一下午(?)一直在机惨别人(?)玩的很开心。但还是想看大家在机房跳钢管舞喵(?A.game赛时看到这个题之后就变得很愚蠢。......
  • 数组直接通过索引修改属性值不能触发watch
    下面说法错误的是()Awatch监听对象必须设置deep:trueB数组直接通过索引修改属性值,能触发watch方法Cwatch内部可以写异步方法Dimmediate:true可以开启首次赋值监听正确答案:B因为没有getter和setter方法,所以数组直接通过索引修改属性值不能触发watchvue无法监听数组......
  • 11.3
    -今天完成了一个分级测试,主要包括不同用户登录的选课系统,主要功能如下:(1)能够在Tomcat服务器中正确部署,并通过浏览器查看;(2)网站页面整体风格统一;(3)首页(登录页)要求实现不同用户登录后,进入的功能页不相同。(4)教师功能页:有添加课程、修改个人信息、浏览选课学生信息三个模块。(5)学......
  • concat()返回一个新的数组,还需要用新数组替换原数组才能实现视图的更新。
    在Vue中,下列哪个选项对数组的操作不会触发视图的更新()Apush()Bshift()Cconcat()Dreverse()正确答案:Cconcat()返回一个新的数组,还需要用新数组替换原数组才能实现视图的更新。七个改变原数组且会让vue监听到的方法。push()在末尾添加一个pop()在末尾删除一个shift(......
  • 11.13
    本周从周一上完课,把那天的学长的期中考试写完,就放松了,没继续练,就把idea一关啥也没关,然后除了正常写作业,已经周二晚上周三早上背了背英语,来应对老师的听写测验,学习的时间分配很少,感觉好像期中考试完了之后,就放松了,周末三天更是除了写了点离散数学作业,一点没学习,导致本周一的分级测......
  • 2023/11/13(可对角化)
    ......