浅谈js的sort()方法

如果调用该方法时没有使用参数,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码(字符串Unicode码点)的顺序进行排序。要实现这一点,首先应把数组的元素都转换成字符串(如有必要),以便进行比较。

怎么获取字符串Unicode编码了?

charAt和charCodeAt

charCodeAt() 方法可返回指定位置的字符的 Unicode 编码。这个返回值是 0 - 65535 之间的整数。
方法 charCodeAt() 与 charAt() 方法执行的操作相似,只不过前者返回的是位于指定位置的字符的编码,而后者返回的是字符子串。

var str = "abcdefg";
console.log(str.charAt(0));                     //a
console.log(str.charCodeAt(0));                 //97
console.log(str.charCodeAt(0).toString(16));    //61

var str2 = "12345677";
console.log(str2.charAt(0));                    //1
console.log(str2.charCodeAt(0));                //49
console.log(str2.charCodeAt(0).toString(16));   //31

var str3 = "数据在计算机中的表示,最终以二进制的形式存在,所以有时候使用二进制";
console.log(str3.charAt(0));                           //数
console.log(str3.charCodeAt(0));                       //25968
console.log(str3.charCodeAt(0).toString(16));          //6570

array.sort()方法默认是升序排序,如果想按照其他标准进行排序,就需要提供比较函数,该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字。比较函数应该具有两个参数 a 和 b,其返回值如下:

  • 若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值。
  • 若 a 等于 b,则返回 0。
  • 若 a 大于 b,则返回一个大于 0 的值。

普通数组升序

var arr = [4,3,6,5,7,2,1];
arr.sort();
console.log(arr);
//输出结果[1,2,3,4,5,6,7]

普通数据降序

var arr = [4,3,6,5,7,2,1];
arr.sort();
arr.sort(function(a,b){
    return b-a;
});
console.log(arr);
//输出结果[7,6,5,4,3,2,1]

对象数组排序

var arr= [
    { ‘sortNo‘: 2},
    { ‘sortNo‘: 1},
    { ‘sortNo‘: 5},
    { ‘sortNo‘: 6},
    { ‘sortNo‘: 7},
    { ‘sortNo‘: 3},
    { ‘sortNo‘: 9},
    { ‘sortNo‘: 4},
    { ‘sortNo‘: 0}
];
arr.sort(function(a, b){
        return a.sortNo - b.sortNo;
});
console.log(arr);
//输出结果
//{ ‘sortNo‘: 2}
//{ ‘sortNo‘: 1}
//{ ‘sortNo‘: 5}
//{ ‘sortNo‘: 6}
//{ ‘sortNo‘: 7}
//{ ‘sortNo‘: 3}
//{ ‘sortNo‘: 9}
//{ ‘sortNo‘: 4}
//{ ‘sortNo‘: 0}

对象数组多条件排序

此例如果sortNo相同,则按sortNo2从大到小

var arr= [
    { ‘sortNo‘: 2, ‘sortNo2‘: 3},
    { ‘sortNo‘: 1, ‘sortNo2‘: 3},
    { ‘sortNo‘: 5, ‘sortNo2‘: 3},
    { ‘sortNo‘: 6, ‘sortNo2‘: 3},
    { ‘sortNo‘: 7, ‘sortNo2‘: 3},
    { ‘sortNo‘: 3, ‘sortNo2‘: 4},
    { ‘sortNo‘: 3, ‘sortNo2‘: 2},
    { ‘sortNo‘: 3, ‘sortNo2‘: 1},
    { ‘sortNo‘: 3, ‘sortNo2‘: 3},
    { ‘sortNo‘: 8, ‘sortNo2‘: 3},
    { ‘sortNo‘: 4, ‘sortNo2‘: 1},
    { ‘sortNo‘: 4, ‘sortNo2‘: 2}
];
arr.sort(function(a, b){
    if (a.sortNo === b.sortNo) {
            return b.sortNo2 - a.sortNo2;
    } else {
            return a.sortNo - b.sortNo;
    }
});
console.log(arr); 

//输出结果
//{ ‘sortNo‘: 1, ‘sortNo2‘: 3}
//{ ‘sortNo‘: 2, ‘sortNo2‘: 3}
//{ ‘sortNo‘: 3, ‘sortNo2‘: 4}
//{ ‘sortNo‘: 3, ‘sortNo2‘: 3}
//{ ‘sortNo‘: 3, ‘sortNo2‘: 2}
//{ ‘sortNo‘: 3, ‘sortNo2‘: 1}
//{ ‘sortNo‘: 4, ‘sortNo2‘: 2}
//{ ‘sortNo‘: 4, ‘sortNo2‘: 1}
//{ ‘sortNo‘: 5, ‘sortNo2‘: 3}
//{ ‘sortNo‘: 6, ‘sortNo2‘: 3}
//{ ‘sortNo‘: 7, ‘sortNo2‘: 3}
//{ ‘sortNo‘: 8, ‘sortNo2‘: 3}  

原文地址:https://www.cnblogs.com/bq-med/p/8582186.html

时间: 2024-10-06 22:03:45

浅谈js的sort()方法的相关文章

浅谈 js 字符串 trim 方法之正则篇

position:static(静态定位) 当position属性定义为static时,可以将元素定义为静态位置,所谓静态位置就是各个元素在HTML文档流中应有的位置 podisition定位问题.所以当没有定义position属性时,并不说明该元素没有自己的位置,它会遵循默认显示为静态位置,在静态定位状态下无法通过坐标值(top,left,right,bottom)来改变它的位置. position:absolute(绝对定位) 当position属性定义为absolute时,元素会脱离文档流

浅谈 js 对象 toJSON 方法

前些天在<浅谈 JSON.stringify 方法>说了他的正确使用姿势,今天来说下 toJSON 方法吧.其实我觉得这货跟 toString 一个道理,他是给 stringify 方法字符串化的时候调用的.看下 MDN 官方文档吧<toJSON behavior>.非常简单,但是要注意的是他和 stringify 方法第二个参数稍微有点不同.因为 stringify 第二个参数是回调函数时,只是对当前 key 对应的值进行修改.而 toJSON 则是对当前对象进行修改.例如: v

浅谈 js 字符串 search 方法

原文:浅谈 js 字符串 search 方法 这是一个很久以前的事情了,好像是安心兄弟在学习js的时候做的练习.具体记不清了,今天就来简单分析下 search 究竟是什么用的. 从字面意思理解,一个是搜索字符串吧. var str = "123456789abcde"; console.log( str.search("abc") ); // 9 确实是搜索指定字符在一个字符串中出现的位置,如果不存在就返回 -1可是这样就跟 indexOf 功能一样了,何必单独搞一

浅谈js的join()方法

简单描述:今天看同事的代码,看js的时候,看到了一个join()方法,我从来都没有用过,就查了查,第一次用就记录一下 正经的: 定义和用法 join() 方法用于把数组中的所有元素放入一个字符串. 元素是通过指定的分隔符进行分隔的. 代码示例: <script type="text/javascript"> var arr = new Array(3) arr[0] = "George" arr[1] = "John" arr[2]

浅谈js数据类型识别方法

js有5种基本数据类型  Undefined , Null , Boolean , Number , String 和一种引用类型Object,下面我们就来一一看穿,哦不,识别他们. typeof 前面5种虽多,但是是基本类型,也容易识别,typeof 操作符就能差不多把他们都识别了,null 不服的站了出来:"能识别我么?",typeof这下犯难了:"你,你你先坐下." typeof对Object基本上是脸盲的,除了function之外看谁都是Object, 数组

浅谈 js 正则之 test 方法

原文:浅谈 js 正则之 test 方法 其实我很少用这个,所以之前一直没注意这个问题,自从落叶那厮写了个变态的测试我才去看了下这东西.先来看个东西吧. ? 1 2 3 4 5 var re = /\d/; console.log( re.test("1") ); console.log( re.test("1") ); console.log( re.test("1") ); console.log( re.test("1"

浅谈 js eval作用域

就简单聊下如何全局 eval 一个代码. var x = 1; (function () { eval('var x = 123;'); })(); console.log(x); 这个代码得到的是 1 而不是 123如果想让 eval 执行的代码是全局的,那么有几种方法. var x = 1; (function () { window.eval('var x = 123;'); })(); console.log(x); 这个方法标准浏览器都可以得到 123 而IE6-8则依然是 1 相同的

浅谈JS之AJAX

0x00:什么是Ajax? Ajax是Asynchronous Javascript And Xml 的缩写(异步javascript及xml),Ajax是使用javascript在浏览器后台操作HTTP和web服务器进行数据交换(用户不知道也感觉不出来,就跟桌面应用程序似的进行数据交互),它不会导致页面重新加载,这样才有更好的用户体验. Ajax是基于以下开放标准: javascript(DOM) css html xml(json) 通俗的说就是使用了javascript(DOM)的XMLH

浅谈js中的this关键字

浅谈js中的this关键字 全局作用域中的this 函数作用域中的this 不同函数调用方法下的this 直接调用 作为对象的方法调用 作为构造函数调用 通过call或apply方法调用 嵌套函数作用域中的this 浅谈js中的this关键字 this是JavaScript中的关键字之一,在编写程序的时候经常会用到,正确的理解和使用关键字this尤为重要.接下来,笔者就从作用域的角度粗谈下自己对this关键字的理解,希望能给到大家一些启示,权当交流之用. 全局作用域中的this 本文将以作用域由