Vue.js 排序方法

引用W3cschool

W3School,javaScript

1.sort() 方法以字母顺序对数组进行排序:

2.反转数组,reverse() 方法反转数组中的元素。

    您可以使用它以降序对数组进行排序:

var fruits = ["Banana", "Orange", "Apple", "Mango"];

fruits.sort(); // 对 fruits 中的元素进行排序   Apple, Banana, Mango, Orange,

fruits.reverse(); // 反转元素顺序  Orange,Mango,Banana,Apple

3.默认地,sort() 函数按照字符串顺序对值进行排序。

该函数很适合字符串("Apple" 会排在 "Banana" 之前)。

不过,如果数字按照字符串来排序,则 "25" 大于 "100",因为 "2" 大于 "1"。

正因如此,sort() 方法在对数值排序时会产生不正确的结果。

我们通过一个<<比值函数>>来修正此问题:

var points = [40, 100, 1, 5, 25, 10];

points.sort(function(a, b){return a - b});

--------------------------------------------------------

<script>var points = [40, 100, 1, 5, 25, 10];

document.getElementById("demo").innerHTML = points;

function myFunction() {

points.sort(function(a, b){return a - b});

document.getElementById("demo").innerHTML = points;

}</script>

//1,5,10,25,40,100

!!降序排序xxx

var points = [40, 100, 1, 5, 25, 10];

points.sort(function(a, b){return b - a}); 

//100,40,25,10,5,1

比值函数

比较函数的目的是定义另一种排序顺序。

比较函数应该返回一个负,零或正值,这取决于参数:

function(a, b){return a-b}

当 sort() 函数比较两个值时,会将值发送到比较函数,并根据所返回的值(负、零或正值)对这些值进行排序。

4.以随机顺序排序数组

    实例

var points = [40, 100, 1, 5, 25, 10];

points.sort(function(a, b){return 0.5 - Math.random()});

5.查找最高(或最低)的数组值


    JavaScript 不提供查找数组中最大或最小数组值的内建函数。

    不过,在对数组进行排序之后,您能够使用索引来获得最高或最低值。

var points = [40, 100, 1, 5, 25, 10];

points.sort(function(a, b){return a - b});

// 现在 points[0] 包含最低值

// 而 points[points.length-1] 包含最高值 

points.sort(function(a, b){return b - a});

// 现在 points[0] 包含最高值

// 而 points[points.length-1] 包含最低值 

6.对数组使用 Math.max()

var points = [40, 100, 1, 5, 25, 10];

function myArrayMax(arr) {

return Math.max.apply(null, arr);

}

最高值是:100

Math.max.apply([1, 2, 3]) 等于 Math.max(1, 2, 3)。

7.对数组使用 Math.min()

function myArrayMin(arr) {

return Math.min.apply(null, arr);

}

Math.min.apply([1, 2, 3]) 等于 Math.min(1, 2, 3)。

8.自制方法

最大值

function myArrayMax(arr) {

var len = arr.length

var max = -Infinity;

while (len--) {

if (arr[len] > max) {

max = arr[len];

} }

return max;}

最小值

function myArrayMin(arr) {

var len = arr.length

var min = Infinity;

while (len--) {

if (arr[len] < min) {

min = arr[len];

} }

return min;

}


10.排序对象数组

JavaScript 数组经常会包含对象:

var cars = [

{type:"Volvo", year:2016},

{type:"Saab", year:2001},

{type:"BMW", year:2010}]; 


即使对象拥有不同数据类型的属性,sort() 方法仍可用于对数组进行排序。

解决方法是通过比较函数来对比属性值:

cars.sort( function ( a , b ){ return  a.year - b.year } );

11.比较字符串

cars.sort(function(a, b){

        var x = a.type.toLowerCase();

        var y = b.type.toLowerCase();

        if (x < y) {return -1;}

        if (x > y) {return 1;}

        return 0;

});

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,122评论 6 505
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,070评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,491评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,636评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,676评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,541评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,292评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,211评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,655评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,846评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,965评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,684评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,295评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,894评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,012评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,126评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,914评论 2 355