// 比如被减数a是10,减数是20 10-20 < 0 被减数a(10)在减数b(20)前面
array.sort(function(a,b){
return a-b;
});
console.log(array); // [1,3,4,4,8,10,20,25];
// 降序 被减数和减数调换了 20-10>0 被减数b(20)在减数a(10)的前面
array.sort(function(a,b){
return b-a;
});
console.log(array); // [25,20,10,8,4,4,3,1];
2、数组多条件排序
var array = [{id:10,age:2},{id:5,age:4},{id:6,age:10},{id:9,age:6},{id:2,age:8},{id:10,age:9}];
array.sort(function(a,b){
if(a.id === b.id){// 如果id的值相等,按照age的值降序
return b.age - a.age
}else{ // 如果id的值不相等,按照id的值升序
return a.id - b.id
}
})
// [{“id”:2,“age”:8},{“id”:5,“age”:4},{“id”:6,“age”:10},{“id”:9,“age”:6},{“id”:10,“age”:9},{“id”:10,“age”:2}]
3、自定义比较函数,天空才是你的极限类似的:
运用好返回值,我们可以写出任意符合自己需求的比较函数
var array = [{name:‘Koro1’},{name:‘Koro1’},{name:‘OB’},{name:‘Koro1’},{name:‘OB’},{name:‘OB’}];
array.sort(function(a,b){
if(a.name === ‘Koro1’){// 如果name是’Koro1’ 返回-1 ,-1<0 a排在b的前面
return -1
}else{ // 如果不是的话,a排在b的后面
return 1
}
})
// [{“name”:“Koro1”},{“name”:“Koro1”},{“name”:“Koro1”},{“name”:“OB”},{“name”:“OB”},{“name”:“OB”}]
ES6: copyWithin() 指定位置的成员复制到其他位置定义: 在当前数组内部,将指定位置的成员复制到其他位置,并返回这个数组。
语法:array.copyWithin(target, start = 0, end = this.length)参数:三个参数都是数值,如果不是,会自动转为数值.
target(必需):从该位置开始替换数据。如果为负值,表示倒数。
start(可选):从该位置开始读取数据,默认为 0。如果为负值,表示倒数。
end(可选):到该位置前停止读取数据,默认等于数组长度。使用负数可从数组结尾处规定位置。
浏览器兼容(MDN): chrome 45,Edge 12,Firefox32,Opera 32,Safari 9, IE 不支持eg:
// -2相当于3号位,-1相当于4号位
[1, 2, 3, 4, 5].copyWithin(0, -2, -1)
// [4, 2, 3, 4, 5]
var a=[‘OB1’,‘Koro1’,‘OB2’,‘Koro2’,‘OB3’,‘Koro3’,‘OB4’,‘Koro4’,‘OB5’,‘Koro5’]
// 2位置开始被替换,3位置开始读取要替换的 5位置前面停止替换
a.copyWithin(2,3,5)
// [“OB1”,“Koro1”,“Koro2”,“OB3”,“OB3”,“Koro3”,“OB4”,“Koro4”,“OB5”,“Koro5”]
从上述栗子:
第一个参数是开始被替换的元素位置
要替换数据的位置范围:从第二个参数是开始读取的元素,在第三个参数前面一个元素停止读取
数组的长度不会改变
读了几个元素就从开始被替换的地方替换几个元素
ES6: fill() 填充数组定义: 使用给定值,填充一个数组。
参数:第一个元素(必须): 要填充数组的值第二个元素(可选): 填充的开始位置,默认值为0第三个元素(可选):
填充的结束位置,默认是为this.lengthMDN浏览器兼容
[‘a’, ‘b’, ‘c’].fill(7)
// [7, 7, 7]
[‘a’, ‘b’, ‘c’].fill(7, 1, 2)
// [‘a’, 7, ‘c’]
不改变原数组的方法(8个):ES5:
join、toLocateString、toStrigin、slice、cancat、indexOf、lastIndexOf、ES7:
includesjoin() 数组转字符串定义: join() 方法用于把数组中的所有元素通过指定的分隔符进行分隔放入一个字符串,返回生成的字符串。
语法:array.join(str)参数:str(可选): 指定要使用的分隔符,默认使用逗号作为分隔符。
let a= [‘hello’,‘world’];
let str=a.join(); // ‘hello,world’
let str2=a.join(‘+’); // ‘hello+world’
使用join方法或者下文说到的toString方法时,当数组中的元素也是数组或者是对象时会出现什么情况?
let a= [[‘OBKoro1’,‘23’],‘test’];
let str1=a.join(); // OBKoro1,23,test
let b= [{name:‘OBKoro1’,age:‘23’},‘test’];
let str2 = b.join(); // [object Object],test
// 对象转字符串推荐JSON.stringify(obj);
所以,join()/toString()方法在数组元素是数组的时候,会将里面的数组也调用join()/toString(),如果是对象的话,对象会被转为[object Object]字符串。
toLocaleString() 数组转字符串定义: 返回一个表示数组元素的字符串。
该字符串由数组中的每个元素的 toLocaleString() 返回值经调用 join() 方法连接(由逗号隔开)组成。
语法:array.toLocaleString()参数:
无。
let a=[{name:‘OBKoro1’},23,‘abcd’,new Date()];
let str=a.toLocaleString(); // [object Object],23,abcd,2021/12/3 下午1:52:20
如上述栗子:
调用数组的toLocaleString方法,数组中的每个元素都会调用自身的toLocaleString方法,对象调用对象的toLocaleString,Date调用Date的toLocaleString。
toString() 数组转字符串 不推荐定义: toString() 方法可把数组转换为由逗号链接起来的字符串。
语法:array.toString()参数: 无。
该方法的效果和join方法一样,都是用于数组转字符串的,但是与join方法相比没有优势,也不能自定义字符串的分隔符,因此不推荐使用。
值得注意的是:
当数组和字符串操作的时候,js 会调用这个方法将数组自动转换成字符串
let b= [ ‘toString’,‘演示’].toString(); // toString,演示
let a= [‘调用toString’,‘连接在我后面’]+‘啦啦啦’; // 调用toString,连接在我后面啦啦啦
slice() 浅拷贝数组的元素定义:
方法返回一个从开始到结束(不包括结束)选择的数组的一部分浅拷贝到一个新数组对象,且原数组不会被修改。
注意:
字符串也有一个slice() 方法是用来提取字符串的,不要弄混了。
语法:array.slice(begin, end);参数:begin(可选): 索引数值,接受负值,从该索引处开始提取原数组中的元素,默认值为0。
end(可选):索引数值(不包括),接受负值,在该索引处前结束提取原数组元素,默认值为数组末尾(包括最后一个元素)。
let a= [‘hello’,‘world’];
let b=a.slice(0,1); // [‘hello’]
a[0]=‘改变原数组’;
console.log(a,b); // [‘改变原数组’,‘world’] [‘hello’]
b[0]=‘改变拷贝的数组’;
console.log(a,b); // [‘改变原数组’,‘world’] [‘改变拷贝的数组’]
如上:
新数组是浅拷贝的,元素是简单数据类型,改变之后不会互相干扰。
如果是复杂数据类型(对象,数组)的话,改变其中一个,另外一个也会改变。
let a= [{name:‘OBKoro1’}];
let b=a.slice();
console.log(b,a); // [{“name”:“OBKoro1”}] [{“name”:“OBKoro1”}]
// a[0].name=‘改变原数组’;
// console.log(b,a); // [{“name”:“改变原数组”}] [{“name”:“改变原数组”}]
// b[0].name=‘改变拷贝数组’,b[0].koro=‘改变拷贝数组’;
// [{“name”:“改变拷贝数组”,“koro”:“改变拷贝数组”}] [{“name”:“改变拷贝数组”,“koro”:“改变拷贝数组”}]
原因在定义上面说过了的:
slice()是浅拷贝,对于复杂的数据类型浅拷贝,拷贝的只是指向原数组的指针,所以无论改变原数组,还是浅拷贝的数组,都是改变原数组的数据。
cancat定义:
方法用于合并两个或多个数组,返回一个新数组。
语法:
var newArr =oldArray.concat(arrayX,arrayX,…,arrayX)参数:
arrayX(必须):
该参数可以是具体的值,也可以是数组对象。
可以是任意多个。
eg1:
let a = [1, 2, 3];
let b = [4, 5, 6];
//连接两个数组
let newVal=a.concat(b); // [1,2,3,4,5,6]
// 连接三个数组
let c = [7, 8, 9]
let newVal2 = a.concat(b, c); // [1,2,3,4,5,6,7,8,9]
// 添加元素
let newVal3 = a.concat(‘添加元素’,b, c,‘再加一个’);
// [1,2,3,“添加元素”,4,5,6,7,8,9,“再加一个”]
// 合并嵌套数组 会浅拷贝嵌套数组
let d = [1,2 ];
let f = [3,[4]];
let newVal4 = d.concat(f); // [1,2,3,[4]]
ES6扩展运算符…合并数组:
因为ES6的语法更简洁易懂,所以现在合并数组我大部分采用…来处理,…运算符可以实现cancat的每个栗子,且更简洁和具有高度自定义数组元素位置的效果。
let a = [2, 3, 4, 5]
let b = [ 4,…a, 4, 4]
console.log(a,b); // [2, 3, 4, 5] [4,2,3,4,5,4,4]
更多关于扩展符的详细内容移步阮一峰大神的ECMAScript 6 入门indexOf() 查找数组是否存在某个元素,返回下标定义: 返回在数组中可以找到一个给定元素的第一个索引,如果不存在,则返回-1。
语法:array.indexOf(searchElement,fromIndex)参数:searchElement(必须):被查找的元素fromIndex(可选):开始查找的位置(不能大于等于数组的长度,返回-1),接受负值,默认值为0。
严格相等的搜索:数组的indexOf搜索跟字符串的indexOf不一样,数组的indexOf使用严格相等===搜索元素,即数组元素要完全匹配才能搜索成功。
注意:
indexOf()不能识别NaNeg:
let a=[‘啦啦’,2,4,24,NaN]
console.log(a.indexOf(‘啦’)); // -1
console.log(a.indexOf(‘NaN’)); // -1
console.log(a.indexOf(‘啦啦’)); // 0
使用场景:
数组去重
根据获取的数组下标执行操作,改变数组中的值等。
判断是否存在,执行操作。
lastIndexOf() 查找指定元素在数组中的最后一个位置定义: 方法返回指定元素,在数组中的最后一个的索引,如果不存在则返回 -1。
(从数组后面往前查找)语法:arr.lastIndexOf(searchElement,fromIndex)参数:searchElement(必须): 被查找的元素fromIndex(可选): 逆向查找开始位置,默认值数组的长度-1,即查找整个数组。
关于fromIndex有三个规则:
正值。如果该值大于或等于数组的长度,则整个数组会被查找。
负值。将其视为从数组末尾向前的偏移。(比如-2,从数组最后第二个元素开始往前查找)
负值。
其绝对值大于数组长度,则方法返回 -1,即数组不会被查找。
let a=[‘OB’,4,‘Koro1’,1,2,‘Koro1’,3,4,5,‘Koro1’]; // 数组长度为10
// let b=a.lastIndexOf(‘Koro1’,4); // 从下标4开始往前找 返回下标2
// let b=a.lastIndexOf(‘Koro1’,100); // 大于或数组的长度 查找整个数组 返回9
// let b=a.lastIndexOf(‘Koro1’,-11); // -1 数组不会被查找
let b=a.lastIndexOf(‘Koro1’,-9); // 从第二个元素4往前查找,没有找到 返回-1
ES7 includes() 查找数组是否包含某个元素 返回布尔定义:
返回一个布尔值,表示某个数组是否包含给定的值语法:
array.includes(searchElement,fromIndex=0)参数:
searchElement(必须):被查找的元素fromIndex(可选):默认值为0,参数表示搜索的起始位置,接受负值。
正值超过数组长度,数组不会被搜索,返回false。
负值绝对值超过长数组度,重置从0开始搜索。
includes方法是为了弥补indexOf方法的缺陷而出现的:
indexOf方法不能识别NaN
indexOf方法检查是否包含某个值不够语义化,需要判断是否不等于-1,表达不够直观
eg:
let a=[‘OB’,‘Koro1’,1,NaN];
// let b=a.includes(NaN); // true 识别NaN
// let b=a.includes(‘Koro1’,100); // false 超过数组长度 不搜索
// let b=a.includes(‘Koro1’,-3); // true 从倒数第三个元素开始搜索
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
最后
技术是没有终点的,也是学不完的,最重要的是活着、不秃。零基础入门的时候看书还是看视频,我觉得成年人,何必做选择题呢,两个都要。喜欢看书就看书,喜欢看视频就看视频。最重要的是在自学的过程中,一定不要眼高手低,要实战,把学到的技术投入到项目当中,解决问题,之后进一步锤炼自己的技术。
CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
技术学到手后,就要开始准备面试了,找工作的时候一定要好好准备简历,毕竟简历是找工作的敲门砖,还有就是要多做面试题,复习巩固。
一个人可以走的很快,但一群人才能走的更远。如果你从事以下工作或对以下感兴趣,欢迎戳这里加入程序员的圈子,让我们一起学习成长!
AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算
看书就看书,喜欢看视频就看视频。最重要的是在自学的过程中,一定不要眼高手低,要实战,把学到的技术投入到项目当中,解决问题,之后进一步锤炼自己的技术。
CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
技术学到手后,就要开始准备面试了,找工作的时候一定要好好准备简历,毕竟简历是找工作的敲门砖,还有就是要多做面试题,复习巩固。
[外链图片转存中…(img-7jJsNNG0-1712268834880)]
一个人可以走的很快,但一群人才能走的更远。如果你从事以下工作或对以下感兴趣,欢迎戳这里加入程序员的圈子,让我们一起学习成长!
AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算