您好,登錄后才能下訂單哦!
這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)?lái)有關(guān)使用vue怎么實(shí)現(xiàn)數(shù)組對(duì)象排序,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
普通數(shù)組的排序
先看代碼:
<div class="app"> <h2>v-for實(shí)例</h2> <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); }, } })
原本我以為會(huì)出來(lái)結(jié)果,可結(jié)果不一樣。。
后來(lái)我想了一下,發(fā)現(xiàn)了其中的問(wèn)題,sort方法會(huì)調(diào)用每個(gè)數(shù)組項(xiàng)的toString()方法,得到字符串,然后再對(duì)得到的字符串進(jìn)行排序。sort()方法的參數(shù)就起到了作用,我們把這個(gè)參數(shù)叫做比較函數(shù)。
解決辦法
加一個(gè)比較函數(shù)
function sortNumbers(a,b){ return a-b; }
咦,怎么結(jié)果還是沒(méi)出來(lái)??原來(lái)我是輸出的時(shí)候忘記吧numbers換成sortNumbers。這是從小到大輸出,那么從大到小呢?很簡(jiǎn)單就是return b-a,
結(jié)果如圖所示:
完整代碼如下:
<!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"> <h2>v-for實(shí)例</h2> <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ù)組對(duì)象的排序
如果數(shù)組項(xiàng)是對(duì)象,我們需要根據(jù)數(shù)組項(xiàng)的某個(gè)屬性對(duì)數(shù)組進(jìn)行排序,要怎么辦呢?其實(shí)和前面的比較函數(shù)也差不多。所以我就只把部分代碼分享出來(lái)了。
如何對(duì)這個(gè)數(shù)組進(jìn)行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ù)來(lái)判斷的,也和下面這個(gè)代碼效果一樣
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; } } }
我覺(jué)得這個(gè)代碼有點(diǎn)冗雜,所以我就用了三元運(yùn)算符來(lái)判斷輸出。
結(jié)果:
整個(gè)項(xiàng)目文件:
<!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"> <h2>v-for實(shí)例</h2> <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ù)組對(duì)象排序 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>
結(jié)果:
上述就是小編為大家分享的使用vue怎么實(shí)現(xiàn)數(shù)組對(duì)象排序了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。