vue數(shù)組對象排序的實現(xiàn)代碼
前言
最近在看vue的教學視頻,正好學到的數(shù)組對象排序方法,在這跟大家分享一下,如有不足之處,請賜教。
普通數(shù)組的排序
先看代碼:
<div class="app"> <h1>v-for實例</h1> <hr> <ol> <li v-for="number in numbers">{{number}}</li> </ol> </div> <script> new Vue({ el:'.app', data:{ numbers:[5 ,88, 43, 56, 28, 61, 9], }, computed:{ numbers:function(){ return this.numbers.sort(numbers); }, } })
原本我以為會出來結果,可結果不一樣。。
后來我想了一下,發(fā)現(xiàn)了其中的問題,sort方法會調用每個數(shù)組項的toString()方法,得到字符串,然后再對得到的字符串進行排序。sort()方法的參數(shù)就起到了作用,我們把這個參數(shù)叫做比較函數(shù)。
解決辦法
加一個比較函數(shù)
function sortNumbers(a,b){ return a-b; }
咦,怎么結果還是沒出來??原來我是輸出的時候忘記吧numbers換成sortNumbers。這是從小到大輸出,那么從大到小呢?很簡單就是return b-a,
結果如圖所示:
完整代碼如下:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>v-for</title> <script src="https://cdn.bootcss.com/vue/2.4.2/vue.min.js"></script> </head> <body> <div class="app"> <h1>v-for實例</h1> <hr> <ol> <li v-for="number in sortNumbers">{{number}}</li> </ol> </div> <script> new Vue({ el:'.app', data:{ numbers:[5 ,88, 43, 56, 28, 61, 9], }, computed:{ sortNumbers:function(){ return this.numbers.sort( sortNumbers); }, } }); function sortNumbers(a,b){ return a-b; } </script> </body> </html>
數(shù)組對象的排序
如果數(shù)組項是對象,我們需要根據(jù)數(shù)組項的某個屬性對數(shù)組進行排序,要怎么辦呢?其實和前面的比較函數(shù)也差不多。所以我就只把部分代碼分享出來了。
如何對這個數(shù)組進行age排序呢
students:[ {name:'cjk',age:'38'} , { name:'xxf',age:'29'}, {name:'zk',age:'26'}, ]
比較函數(shù):
function sortByKey(array,key){ return array.sort(function(a,b){ var x = a[key]; var y = b[key]; return((x<y)?-1:((x>y)?1:0)); }) }
這里我是用三元函數(shù)來判斷的,也和下面這個代碼效果一樣
var compare = function (prop) { return function (obj1, obj2) { var val1 = obj1[prop]; var val2 = obj2[prop];if (val1 < val2) { return -1; } else if (val1 > val2) { return 1; } else { return 0; } } }
我覺得這個代碼有點冗雜,所以我就用了三元運算符來判斷輸出。
結果:
整個項目文件:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>v-for</title> <script src="https://cdn.bootcss.com/vue/2.4.2/vue.min.js"></script> </head> <body> <div class="app"> <h1>v-for實例</h1> <hr> <ol> <li v-for="number in sortNumbers">{{number}}</li> </ol> <hr> <ul> <li v-for="(student,index) in sortstudents">{{index+1}}:{{student.name}}-{{student.age}}</li> </ul> </div> <script> new Vue({ el:'.app', data:{ numbers:[5 ,88, 43, 56, 28, 61, 9], students:[ {name:'cjk',age:'38'} , { name:'xxf',age:'29'}, {name:'zk',age:'26'}, ] }, computed:{ sortNumbers:function(){ return this.numbers.sort( sortNumbers); }, sortstudents:function(){ return sortByKey(this.students,'age') } } }); function sortNumbers(a,b){ return a-b; } //數(shù)組對象排序 function sortByKey(array,key){ return array.sort(function(a,b){ var x = a[key]; var y = b[key]; return((x<y)?-1:((x>y)?1:0)); }) } </script> </body> </html>
結果:
希望這篇文章對新手有用,也希望你們能和我一起分享知識,一起成長。也希望大家多多支持腳本之家。
相關文章
Element實現(xiàn)表格嵌套、多個表格共用一個表頭的方法
這篇文章主要介紹了Element實現(xiàn)表格嵌套、多個表格共用一個表頭的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-05-05Vue2.0+Vux搭建一個完整的移動webApp項目的示例
這篇文章主要介紹了Vue2.0+Vux搭建一個完整的移動webApp項目的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-03-03vue2.0 + ele的循環(huán)表單及驗證字段方法
今天小編就為大家分享一篇vue2.0 + ele的循環(huán)表單及驗證字段方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09Vue引入sign-canvas實現(xiàn)簽名畫板效果
這篇文章主要介紹了Vue引入sign-canvas實現(xiàn)簽名畫板,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-03-03在vue中使用eacharts創(chuàng)建graph關系圖方式
這篇文章主要介紹了在vue中使用eacharts創(chuàng)建graph關系圖方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09深入理解與使用keep-alive(配合router-view緩存整個路由頁面)
這篇文章主要介紹了深入理解與使用keep-alive(配合router-view緩存整個路由頁面),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-09-09