vue中点击添加类名,并且实现升降序

1.介绍

要求:掌握indexOf()用法;动态绑定类名的对象写法;iconfont使用;split()用法;三元运算符用法;es6模板字符串;

说明:首先综合元素默认有元素并且是降序。服务器传来的数据格式:1: 综合,2: 价格 asc: 升序,desc: 降序 。下面意思是综合,降序。它放在data中searchParams.order里面做响应式数据。

2.vue

说明:采用但是iconfont图标。类名,如果从data里面存入的数据查出1(!=-1),说明就是综合;为li绑定了点击事件,传入了1代表是点击的是综合元素;span标签是为了点击后,有一个升序或者降序的一个图标。如果isAsc为true,那么展示的就是升序图标,那么如果是isDesc为true,那么展示的就是降序。

html 复制代码
<li
  :class="{ active: searchParams.order.indexOf('1') != -1 }"
     @click="changeOrder(1)"
                >
     <a>综合<span
         class="iconfont"
          :class="{ 'icon-up-arrow': isAsc, 'icon-down': isDesc }"
          v-show="searchParams.order.indexOf('1') != -1"
           ></span></a>
  </li>
 <li
      :class="{ active: searchParams.order.indexOf('2') != -1 }"
      @click="changeOrder(2)"
                >
       <a>价格<span
           class="iconfont icon-down"
              :class="{ 'icon-up-arrow': isAsc, 'icon-down': isDesc }"
               v-show="searchParams.order.indexOf('2') != -1"
                ></span></a>
</li>

3.js

说明:书写必要的计算属性。如果从order.indexOf("asc")!=-1,代表着是升序。

javascript 复制代码
      isAsc() {
        return this.searchParams.order.indexOf("asc") !== -1;
      },
      isDesc() {
        return this.searchParams.order.indexOf("desc") !== -1;
      },

4.js

说明:methods里面,点击事件触发,首先我们存储在order数据(vuex三连环获取)进行拆分,数据的格式是[1:desc]。首先我们将综合和排序进行拆分。声明一个新的order属性,判断用户当前点击的是综合还是价格,首先默认就是综合,并且是降序。因此如果相等,那么就成了asc。如果不相等那么desc。否则,用户点击的就是价格了,点击后让他默认降序,然后将newOrder替换order。发送网络请求。

javascript 复制代码
    changeOrder(flag) {
      // 获取的是当前状态,当你改变以后,就成了2:desc
      let originOrder = this.searchParams.order;
      // console.log(originOrder);
      // 综合还是价格
      let originFlag = originOrder.split(":")[0];
      // 升序还是降序
      let originSort = originOrder.split(":")[1];
      //  准备一个新的order属性
      let newOrder = "";
      // 一定是综合(默认)并且默认也是降序
      if (flag == originFlag) {
        // 格式是浏览器规定的
        newOrder = `${originFlag}:${originSort == "desc" ? "asc" : "desc"}`;
      } else {
        // 点击的价格
        newOrder = `${flag}:${"desc"}`;
        // console.log(newOrder);
      }
      this.searchParams.order = newOrder;
      this.getData();
    },

5.请求函数

说明:请求封装成函数,直接调用。

javascript 复制代码
    getData() {
      this.$store.dispatch("getSearchList", this.searchParams);
      //  alert("执行了啊")
    },
相关推荐
Aniugel4 小时前
单点登录(SSO)系统
前端
颜酱4 小时前
二叉树遍历思维实战
javascript·后端·算法
鹏多多4 小时前
移动端H5项目,还需要react-fastclick解决300ms点击延迟吗?
前端·javascript·react.js
serioyaoyao4 小时前
上万级文件一起可视化,怎么办?答案是基于 ParaView 的远程可视化
前端
万少4 小时前
端云一体 一天开发的元服务-奇趣故事匣经验分享
前端·ai编程·harmonyos
WindrunnerMax4 小时前
从零实现富文本编辑器#11-Immutable状态维护与增量渲染
前端·架构·前端框架
不想秃头的程序员4 小时前
Vue3 封装 Axios 实战:从基础到生产级,新手也能秒上手
前端·javascript·面试
数研小生4 小时前
亚马逊商品列表API详解
前端·数据库·python·pandas
你听得到114 小时前
我彻底搞懂了 SSE,原来流式响应效果还能这么玩的?(附 JS/Dart 双端实战)
前端·面试·github
不倒翁玩偶4 小时前
npm : 无法将“npm”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确保路径正确,然后再试一次。
前端·npm·node.js