JavaScript之ES6数组排序高逼格!

更新时间:2023-06-09 11:05:53 阅读: 评论:0

JavaScript之ES6数组排序⾼逼格!
前⾔:
针对于前端开发者来讲、数组排序的应⽤场景其实并不多,⼤多数情况下都是后台数据排序之后再返回给前端。但是很多⾯试题中会经常遇到数组排序的问题,经典案例有冒泡排序、插⼊排序、选择排序等等... 逻辑性⽐较强硬。为了追求完美、拒绝花⾥胡哨,所以今天写⼀篇以ES6相关知识实现排序的⽂章、并且挂载⾄原型链上⽅便使⽤,希望对⼤家的开发有所帮助!
技术点:
ES6中 sort()⽅法、箭头函数,prototype原型、继承。
⾸先、简单看⼀下 sort() 能做什么事情:
袁隆平英语作文
sort():⽅法⽤原地计算对数组的元素进⾏排序,并返回排序之后的数组。
tequlia//sort的基本使⽤
let arr = [8, 1, 4, 3, 7, 9]
let Arr = [21, 55, 29, 105, 45]
console.log(arr.sort()) //[1, 3, 4, 7, 8, 9]
console.log(Arr.sort()) // [105, 21, 29, 45, 55]
原则英语由上述代码可知:sort()⽅法只能对0-9以内的数组进⾏正确排序,两位数以上的数组项虽然给出了返回值,但却并不是排序后的结果。这是因为sort()是内部做的是根据ASCLL码进⾏排序的,并不是根据数值⼤⼩排序。那这个⽅法连两位数以上的数字都⽆法进⾏正规排序处理,跟咸鱼有什么区别呢?
重点来了:sort()可以接收⼀个携带两个形参的callback(a,b),即a、b是两个即将要⽐较⼤⼩的元素,且必须要有返回值。释学诚
当callback的返回值是正数时、那么 b 会被排列到 a 之前;
当callback的返回值是负数时、那么 a 会被排列到 b 之前;
当callback的返回值是为 0 时、那么 a 与 b 的位置保持不变;
sort每执⾏⼀次会根据返回值调换两个参数a、b在原数组中的位置;
看完上⾯的描述你会很蒙圈,你⼀定会问返回值在哪?参数 a b 的实参是谁?这些当你看懂下⾯代码之后统统⼩⼉科!
//sort 内部写法
let Arr = [56, 21, 29, 105, 45]
Arr.sort(function(a, b) { //callback
荷兰的英文翻译if (a > b) { // a b 分别是Arr中的 56 21
return 1  //返回正数,b排列在a之前
} el {
return -1 //返回负数,a排列在b之前
祈使句是什么意思}
nostalgia
})
console.log(Arr) //[21, 29, 45, 55, 105]
执⾏逻辑:
需要注意的是callback( a , b )接收的两个参数分别是a = > 当前项、b当前项的下⼀项,若当前项与下⼀项位置不变时,b为下⼀项索引-1;判断遍历结束的条件是b参数取不到值 即结束,举例上述代码中第三轮第⼆次执⾏时 当前项的索引是3 那么b为下⼀项,即4 数组中取不到第4项,不满⾜继续遍历条件,结束遍历!
谈谈返回值:上述代码写的返回值 1 与 -1 只是象征性的代表 1为正数 -1为负数,不论你代码写什么返回值,sort内部只会去判断你的返回值是正数还是负数,哪怕等式成⽴返回100 不成⽴返回-10000都是可⾏的。
解释简写⽅式:
//简写最终版
let Arr = [56, 21, 88, 10, 5, 77]
Arr.sort((a, b) => a - b) //箭头函数不加⼤括号指向这个函数的返回值,可以不写return关键字
console.log(Arr) //[5, 10, 21, 56, 77, 88]
由上图可知,回调函数内部的处理⽅式是a - b ,⽽不再是对⽐两个数。这是因为对⽐两个数的这⼀步操作是sort去做的,你只需要规定返回值即可,恰好数学定义⼤数 - ⼩数 = 正数 、⼩数 - ⼤数 = 负数
举例 56 - 21 = 35 为正数、则返回值为正数,正数代表改变位置;
21 - 88 = 35 为负数、则返回值为负数,负数代表改变位置;
如果数学中⼤数 - ⼩数 ≠ 正数 、⼩数 - ⼤数 ≠ 负数,就不能这么简写。所以要明确的是sort内部做的是互相对⽐ ⽽不是互减;
挂载⾄原型:MySort()
我们也可以模拟Arrar对象继承原型链上的写法,定义⾃⼰的数组操作⽅法,实现直接 Arr.MySort()就可以⾃⼰排序:yanko
//挂载原型
Array.prototype.MySort = function() {
return this.sort((a, b) => a - b)  //箭头函数不加⼤括号时指向这个函数的返回值,可以不写return关键字
}
let Arr = [56, 21, 88, 10, 5, 77]
diwali
Arr.MySort() //调⽤
console.log(Arr) // [5, 10, 21, 56, 77, 88]
需要注意的是MySort中this指向被调⽤者,即谁掉他 他就指向谁,如果此处使⽤箭头函数那么this指向window对象!
在开发过程中还是建议⼤家使⽤ if 的写法,因为这样简写 写法看起来逼格很⾼,但是不⼀定⼈⼈都知道你这样写是什么意思,更建议不要⽆注释的在原型链上挂载任何⾃定义⽅法,说不定后期维护你代码的程序猿就会去百度搜索MySort的⽤法,搜不到还会⼝吐芬芳说百度辣鸡。不利于代码后期的维护,最好的代码不是写的少,⽽是⼈⼈都看得懂!
如果我的博客帮助你解决了开发问题,请不要吝啬你的⼩红⼼哦!❤
上海教育● 若有错误欢迎指出、及时修正 ●

本文发布于:2023-06-09 11:05:53,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/fan/90/139148.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:排序   返回值   数组   代码   负数   函数   正数
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图