JavaScript 数组排序:按字母顺序对数组某个属性进行排序

本文介绍JavaScript中数组排序方法sort()的使用,特别是如何通过自定义排序函数实现根据对象属性进行升序或降序排列。提供了具体示例代码,展示了如何对包含姓名属性的数组对象进行排序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<!DOCTYPE html>
<html>
<body>

<h1>JavaScript 数组排序</h1>

<p>sort() 方法按字母顺序对数组进行排序。</p>

<button onclick="myFunction()">试一试</button>

<p id="demo"></p>

<script>


var arr = [
    {name:'a',age:0},
    {name:'b',age:18},
    {name:'d',age:8},
    {name:'c',age:8},
    {name:'A',age:0},
    {name:'C',age:18},
    {name:'D',age:8},
    {name:'B',age:8}
];


/**数组根据数组对象中的某个属性值进行排序的方法 
     * 使用例子:newArray.sort(sortBy('number',false)) //表示根据number属性降序排列;若第二个参数不传递,默认表示升序排序
     * @param attr 排序的属性 如number属性
     * @param rev true表示升序排列,false降序排序
     * */
function sortBy(attr,rev){
    //第二个参数没有传递 默认升序排列
    if(rev ==  undefined){
      rev = 1;
    }else{
      rev = (rev) ? 1 : -1;
    }

    return function(a,b){
      a = a[attr];
      b = b[attr];
      if(a < b){
        return rev * -1;
      }
      if(a > b){
        return rev * 1;
      }
      return 0;
    }
  }

document.getElementById("demo").innerHTML =JSON.stringify(arr.sort(sortBy('name',true)))

</script>

</body>
</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值