欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue數(shù)組對(duì)象排序的實(shí)現(xiàn)代碼

 更新時(shí)間:2018年06月20日 14:44:33   作者:謝賢飛  
這篇文章主要介紹了vue數(shù)組對(duì)象排序的實(shí)現(xiàn)代碼,這里整理了詳細(xì)的代碼,非常具有實(shí)用價(jià)值,需要的朋友可以參考下

前言

最近在看vue的教學(xué)視頻,正好學(xué)到的數(shù)組對(duì)象排序方法,在這跟大家分享一下,如有不足之處,請(qǐng)賜教。

普通數(shù)組的排序

先看代碼:

<div class="app">
   <h1>v-for實(shí)例</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);
     },
   }
 })

原本我以為會(huì)出來結(jié)果,可結(jié)果不一樣。。


后來我想了一下,發(fā)現(xià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é)果還是沒出來??原來我是輸出的時(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">
   <h1>v-for實(shí)例</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ù)組對(duì)象的排序

如果數(shù)組項(xiàng)是對(duì)象,我們需要根據(jù)數(shù)組項(xiàng)的某個(gè)屬性對(duì)數(shù)組進(jìn)行排序,要怎么辦呢?其實(shí)和前面的比較函數(shù)也差不多。所以我就只把部分代碼分享出來了。

如何對(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ù)來判斷的,也和下面這個(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;
    }      
  } 
}

我覺得這個(gè)代碼有點(diǎn)冗雜,所以我就用了三元運(yùn)算符來判斷輸出。

結(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">
   <h1>v-for實(shí)例</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ù)組對(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é)果:


希望這篇文章對(duì)新手有用,也希望你們能和我一起分享知識(shí),一起成長(zhǎng)。也希望大家多多支持腳本之家。

相關(guān)文章

  • vuex actions傳遞多參數(shù)的處理方法

    vuex actions傳遞多參數(shù)的處理方法

    今天小編就為大家分享一篇vuex actions傳遞多參數(shù)的處理方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vue中使用axios的作用

    vue中使用axios的作用

    Axios是一個(gè)功能強(qiáng)大、易用性高的HTTP庫,適用于大多數(shù)的前端項(xiàng)目,它提供了豐富的功能和靈活的配置選項(xiàng),可以滿足不同項(xiàng)目的需求,這篇文章主要介紹了vue中使用axios的作用,需要的朋友可以參考下
    2023-08-08
  • 解決vue報(bào)錯(cuò)'超出最大堆棧大小'問題

    解決vue報(bào)錯(cuò)'超出最大堆棧大小'問題

    這篇文章主要介紹了解決vue報(bào)錯(cuò)'超出最大堆棧大小'問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • Element實(shí)現(xiàn)表格嵌套、多個(gè)表格共用一個(gè)表頭的方法

    Element實(shí)現(xiàn)表格嵌套、多個(gè)表格共用一個(gè)表頭的方法

    這篇文章主要介紹了Element實(shí)現(xiàn)表格嵌套、多個(gè)表格共用一個(gè)表頭的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05
  • Vue2.0+Vux搭建一個(gè)完整的移動(dòng)webApp項(xiàng)目的示例

    Vue2.0+Vux搭建一個(gè)完整的移動(dòng)webApp項(xiàng)目的示例

    這篇文章主要介紹了Vue2.0+Vux搭建一個(gè)完整的移動(dòng)webApp項(xiàng)目的示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-03-03
  • vue2.0 + ele的循環(huán)表單及驗(yàn)證字段方法

    vue2.0 + ele的循環(huán)表單及驗(yàn)證字段方法

    今天小編就為大家分享一篇vue2.0 + ele的循環(huán)表單及驗(yàn)證字段方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vue實(shí)現(xiàn)購物車選擇功能

    vue實(shí)現(xiàn)購物車選擇功能

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)購物車選擇功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-01-01
  • Vue引入sign-canvas實(shí)現(xiàn)簽名畫板效果

    Vue引入sign-canvas實(shí)現(xiàn)簽名畫板效果

    這篇文章主要介紹了Vue引入sign-canvas實(shí)現(xiàn)簽名畫板,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-03-03
  • 在vue中使用eacharts創(chuàng)建graph關(guān)系圖方式

    在vue中使用eacharts創(chuàng)建graph關(guān)系圖方式

    這篇文章主要介紹了在vue中使用eacharts創(chuàng)建graph關(guān)系圖方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • 深入理解與使用keep-alive(配合router-view緩存整個(gè)路由頁面)

    深入理解與使用keep-alive(配合router-view緩存整個(gè)路由頁面)

    這篇文章主要介紹了深入理解與使用keep-alive(配合router-view緩存整個(gè)路由頁面),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-09-09

最新評(píng)論