JavaScript中的sort如果对字符串对象进行排序,排序规则是怎样的

JavaScript019

JavaScript中的sort如果对字符串对象进行排序,排序规则是怎样的,第1张

对字符串数组排序很简单,只需要直接用sort()即可,这是它的默认排序方式(按字符顺序或者说按字符的ASCII码顺序):

var a = ["666", "123", "4", "88", "1111"]

alert(a.sort()) //1111,123,4,666,88

如果是数值数组,也直接使用sort()的话,也是按字符方式来排序的,需要给sort提供一个自定义的排序规则函数才能实现按数值大小排序:

var a = [666, 123, 4, 88, 1111]

alert(a.sort()) //1111,123,4,666,88

alert(a.sort(function(a, b){return a-b})) //4, 88, 123, 666, 1111

如果是对象数组,要根据对象中一个共同的属性值来排序,则情况要复杂得多,需要定义一个比较函数来实现:

var a = [{"name":"张三", "age":34}, {"name":"李四", "age":28}, {"name":"王五", "age":45}, {"name":"赵六", "age":37}]

a.sort(function(n){

return function(o,p){

var a,b

if(typeof o==="object"&&typeof p==="object"&&o&&p){

a=o[n]

b=p[n]

if(a===b)return 0

if(typeof a===typeof b)return a<b?-1:1

return typeof a<typeof b?-1:1

}else{

throw "error"

}

}

}("age")) //排序结果此略

JS数组多条件排序基于Array.sort()方法,首先要了解sort()方法的用法。

sort()方法可以传入一个函数作为参数,然后依据该函数的逻辑,进行数组的排序。

eg:

sort()方法接收函数作为参数时,排序主要根据传入函数的返回值是否大于0进行排序。

1)当 a-b <0时,则a元素排在b元素的前面;(a、b元素位置不变)

2)当a-b= 0时,a,b元素的位置不变;

3)当a-b >0时,则b元素排在a元素的前面。(a、b元素位置交换)

当数组元素为对象时,若要根据对象的多个属性进行排序,就涉及到多条件排序。

本文实例讲述了js使用Array.prototype.sort()对数组对象排序的方法。分享给大家供大家参考。具体分析如下:

在讲对数组对象进行排序时,我们先来简单的了解一下Array.prototype.sort()。sort方法接受一个参数——Function,function会提供两个参数,分别是两个进行比较的元素,如果元素是String类型则通过Unicode

code进行比较,如果是Number类型则比较值的大小。如果比较的函数中返回1则两个元素交换位置,0和-1不交换位置。先看一个例子:

复制代码

代码如下:var

arr

=

[3,

5,

2,

1]

//

从小到大排序

arr.sort(function

(a,

b)

{

return

a

>

b

?

1

:

-1

})

//

得到的结果:[1,

2,

3,

5]

那么回到我们的主题,如果是对一个数组对象进行排序,该怎么写呢?其实原理和上面一样,如:

复制代码

代码如下:var

arr

=

[

{

a

:

2,

b

:

3.2},

{

a

:

3,

b

:

1.2},

{

a

:

4,

b

:

2.2},

{

a

:

6,

b

:

1.2},

{

a

:

5,

b

:

3.2}

]

///

从小到大按属性b排序

arr.sort(function(x,

y){

return

x.b

>

y.b

?

1:-1

})

x和y就是arr的一个元素,即一个对象,所以直接比较两个对象的属性即可。

上面的例子中,最小的元素中有重复,如果需求是:先按b属性从小到大排序,如果最小中有重复则再按a属性排序,那应该怎么写呢?

在排序的时候,先按b属性排序,如果x.b的大于y.b则将x移到y的右边,如果x.b等于y.b则再通过x.a和y.a进行比较,所以代码如下:

复制代码

代码如下:arr.sort(function

(x,

y)

{

if

(x.b

>

y.b)

{

return

1

}

else

if

(x.b

===

y.b)

{

return

x.a

>

y.a

?

1

:

-1

}

else

if

(x.b

<

y.b)

{

return

-1

}

})

希望本文所述对大家的javascript程序设计有所帮助。