封装升降排序功能组件

文章介绍了JavaScript中数组的sort()函数默认按字符串排序的特性,以及如何通过传入比较函数实现数字数组的正确排序。同时,展示了在Vue.js中如何利用v-if和点击事件实现列表的升序和降序切换功能。

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

1、方法 (js)sort()数组排序
sort()默认按照字符串排序,reverse()可以倒序
 

const arr = ['d', 's', 'a', 'c', 'b']
console.log(arr.sort())//[ 'a', 'b', 'c', 'd', 's' ]
const arr2 = [7, 6, 9, 18, 12]
console.log(arr2.sort())//[ 12, 18, 6, 7, 9 ]
//这里之所以不是[6,7,9,12,18]是因为sort()默认按照字符串排序,他会默认把12,18先取1往后比较
const arr3 = arr2.sort((a, b) => {
    return a - b 
})
console.log(arr3)//[ 6, 7, 9, 12, 18 ]

//从小到大排序,

2、简单升降序

html:

//v-if 就是当变量flag为true时创建改按钮为非true时删除
 //然后绑定点击事件
  <button v-if="flag" @click="sortFun">升序</button>
  <button v-if="!flag" @click="sortFun">降序</button>


data:

// flag: true, //定义显示隐藏的变量


script:

//排序方法 —— 通过id   要是通过价格的话直接用price替换掉id就可以了
    sortFun() {
      if (this.flag) {
        this.lcList.sort((a, b) => {
          return a.id - b.id;
        });
      } else {
        this.lcList.sort((a, b) => {
          return b.id - a.id;
        });
      }
      this.flag = !this.flag;
    },

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值