前言
针对一个数组进行排序,一个很常见的需求.尤其在后端.当然,前端也是有这个需求的.
我们先开看下这个.
标准答案,sort方法
运行结果如下:
这里需要注意的是,sort默认是按照字母顺序来进行排序的.因此,我们在排列数字的时候,需要一个自定义函数.
如上面的代码
function(a,b){return a-b}
这就是一个从小到大的排序函数.看上去好简单的样子,但是我不理解,所以,我根据我的想法,来实现排序吧~
我的答案,for方法排序
运行结果如下图所示
我的方法中的知识点
1.当一个函数需要返回多条数据的时候,使用json对象格式比较方便.如上面的return {"minNum":minNum,"index":index};
2.如果使用 var arrOld = arr 这种方法来复制一个数组,并且,对arrOld进行操作的话,是会影响到arr这个原数组的.
因为javascript分原始类型与引用类型(与java、c#类似)。Array是引用类型。arrOld得到的是引用,所以对arrOld的修改会影响到arr
。复制数组的方法(一)var arrOld = arr.concat();,原理:concat()函数是用于拼接多个数组的函数,这种写法相当于拼接自己.也就是复制了.
复制数组的方法(二)var arrOld = arr.slice(0),原理:slice()函数是一个截取数组的函数,设置值为0,则是全部截取,相当于复制了.
3.splice()方法用于插入、删除或替换数组的元素。这里是使用了其删除数组中指定位置的特性.
我的方法没有修改原数组,而sort是在原数组的基础上进行的修改. 我的方法返回的是一个新数组,原数组并没有消失或者改变.(好像和上面一句是一个意思….)
5.排序是编程中非常非常基础并且非常非常重要的知识点.sort排序在执行大量数据的情况下,效率还是比较低的.当然,我的方法的效率也是很低的.
以上所述是小编给大家介绍的JavaScript sort数组排序方法和自我实现排序方法小结的全部内容,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的,在此也非常感谢大家对编程之家网站的支持。