vue数组对象排序的实现代码


Posted in Javascript onJune 20, 2018

前言

最近在看vue的教学视频,正好学到的数组对象排序方法,在这跟大家分享一下,如有不足之处,请赐教。

vue数组对象排序的实现代码

普通数组的排序

先看代码:

<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);
     },
   }
 })

原本我以为会出来结果,可结果不一样。。

vue数组对象排序的实现代码

后来我想了一下,发现了其中的问题,sort方法会调用每个数组项的toString()方法,得到字符串,然后再对得到的字符串进行排序。sort()方法的参数就起到了作用,我们把这个参数叫做比较函数。

解决办法

加一个比较函数

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

咦,怎么结果还是没出来??原来我是输出的时候忘记吧numbers换成sortNumbers。这是从小到大输出,那么从大到小呢?很简单就是return b-a,

结果如图所示:

vue数组对象排序的实现代码

完整代码如下:

<!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>

数组对象的排序

如果数组项是对象,我们需要根据数组项的某个属性对数组进行排序,要怎么办呢?其实和前面的比较函数也差不多。所以我就只把部分代码分享出来了。

如何对这个数组进行age排序呢

students:[
        {name:'cjk',age:'38'} ,
        { name:'xxf',age:'29'},
        {name:'zk',age:'26'},
     ]

比较函数:

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));
  })
}

这里我是用三元函数来判断的,也和下面这个代码效果一样

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;
    }      
  } 
}

我觉得这个代码有点冗杂,所以我就用了三元运算符来判断输出。

结果:

vue数组对象排序的实现代码

整个项目文件:

<!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;
  }
  //数组对象排序
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>

结果:

vue数组对象排序的实现代码

希望这篇文章对新手有用,也希望你们能和我一起分享知识,一起成长。也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript面向对象之共享成员属性与方法及prototype关键字用法
Jan 13 Javascript
jQuery+jsp实现省市县三级联动效果(附源码)
Dec 03 Javascript
JavaScript+html5 canvas实现本地截图教程
Apr 16 Javascript
JavaScript模版引擎的基本实现方法浅析
Feb 15 Javascript
JavaScript判断微信浏览器实例代码
Jun 13 Javascript
html+js实现简单的计算器代码(加减乘除)
Jul 12 Javascript
vue深入解析之render function code详解
Jul 18 Javascript
Vue-component全局注册实例
Sep 06 Javascript
jQuery实现动态添加和删除input框实例代码
Mar 26 jQuery
微信小程序发布新版本时自动提示用户更新的方法
Jun 07 Javascript
小谈angular ng deploy的实现
Apr 07 Javascript
详解vue-router的导航钩子(导航守卫)
Nov 02 Javascript
vue项目实现github在线预览功能
Jun 20 #Javascript
node thread.sleep实现示例
Jun 20 #Javascript
解决循环中setTimeout执行顺序的问题
Jun 20 #Javascript
Vue.use源码学习小结
Jun 20 #Javascript
Vuex入门到上手教程
Jun 20 #Javascript
JavaScript 中的 this 工作原理
Jun 20 #Javascript
如何用webpack4带你实现一个vue的打包的项目
Jun 20 #Javascript
You might like
PHP读取MySQL数据代码
2008/06/05 PHP
PHP应用JSON技巧讲解
2013/02/03 PHP
PHP获取当前所在目录位置的方法
2014/11/26 PHP
php中解析带中文字符的url函数分享
2015/01/20 PHP
Laravel中9个不经常用的小技巧汇总
2019/04/16 PHP
JavaScript 在各个浏览器中执行的耐性
2009/04/06 Javascript
防止页面被iframe(兼容IE,Firefox火狐)
2010/07/04 Javascript
Dom 学习总结以及实例的使用介绍
2013/04/24 Javascript
浅析Node在构建超媒体API中的作用
2014/07/30 Javascript
jquery不常用方法汇总
2015/07/26 Javascript
基于BootStrap Metronic开发框架经验小结【二】列表分页处理和插件JSTree的使用
2016/05/12 Javascript
javascript之with的使用(阿里云、淘宝使用代码分析)
2016/10/11 Javascript
利用js获取下拉框中所选的值
2016/12/01 Javascript
JavaScript原生实现观察者模式的示例
2017/12/15 Javascript
vue addRoutes实现动态权限路由菜单的示例
2018/05/15 Javascript
angularJs中$scope数据序列化的实例
2018/09/30 Javascript
JS实现选项卡效果的代码实例
2019/05/20 Javascript
Vue.extend 编程式插入组件的实现
2019/11/18 Javascript
jQuery冲突问题解决方法
2021/01/19 jQuery
python发腾讯微博代码分享
2014/01/10 Python
Python中用于计算对数的log()方法
2015/05/15 Python
fastcgi文件读取漏洞之python扫描脚本
2017/04/23 Python
Tensorflow使用支持向量机拟合线性回归
2018/09/07 Python
Python内置数据类型list各方法的性能测试过程解析
2020/01/07 Python
python 两个一样的字符串用==结果为false问题的解决
2020/03/12 Python
Python实现检测文件的MD5值来查找重复文件案例
2020/03/12 Python
python 轮询执行某函数的2种方式
2020/05/03 Python
使用HTML5的Canvas绘制曲线的简单方法
2015/09/08 HTML / CSS
AmazeUI框架搭建的方法步骤(图文)
2020/08/17 HTML / CSS
CheapTickets香港机票预订网站:CheapTickets.hk
2019/06/26 全球购物
党员2014两会学习心得体会
2014/03/17 职场文书
秋天的雨教学反思
2014/04/27 职场文书
婚前保证书
2014/04/29 职场文书
建筑学专业自荐书
2014/07/09 职场文书
2015年副班长工作总结
2015/05/15 职场文书
三十年同学聚会感言
2015/07/30 职场文书