Vue-列表过滤排序

列表过滤

基础环境

  • 数据
javascript 复制代码
persons: [
   { id: "001", name: "刘德华", age: 19 },
   { id: "002", name: "马德华", age: 20 },
   { id: "003", name: "李小龙", age: 21 },
   { id: "004", name: "释小龙", age: 18 },
 ]
  • 根据 名称模糊过滤

监听属性

  • 代码
javascript 复制代码
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <title>列表过滤</title>
    <!--  引入Vue  -->
    <script type="text/javascript" src="../js/vue.js"></script>
    <style>
      .base {
        padding: 5px;
        height: 100px;
      }
    </style>
  </head>
  <body>
    <div id="root">
      <h1>列表过滤</h1>
      <div>
        <h2>数组</h2>
        <input type="text" placeholder="请输入名称" v-model="filterName" />
        <ul>
          <!-- :key="item.id" :key="index" -->
          <li v-for="(item,index) in filterPersons" :key="item.id">
            {{index}}-{{item.id}}-{{item.name}}
          </li>
        </ul>
      </div>
    </div>
  </body>
  <script type="text/javascript">
    Vue.config.productionTip = false; // 阻止vue在启动是生成生产提示
    const vm = new Vue({
      el: "#root",
      data: {
        name: "Vue 扛把子",
        persons: [
          { id: "001", name: "刘德华", age: 19 },
          { id: "002", name: "马德华", age: 20 },
          { id: "003", name: "李小龙", age: 21 },
          { id: "004", name: "释小龙", age: 18 },
        ],
        filterName: "",
        filterPersons: [],
      },

      methods: {},
      watch: {
        filterName: {
          immediate: true,
          handler(newValue) {
            onsole.log("filterName new value => " + newValue);
            if (newValue === "") {
              this.filterPersons = this.persons;
            } else {
              this.filterPersons = this.persons.filter((item) => {
                return item.name.indexOf(newValue) > -1;
              });
            }
          },
        },
      },
    });
  </script>
</html>
  • 效果

初始化

搜索

清空

计算属性

  • 代码
javascript 复制代码
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <title>列表过滤</title>
    <!--  引入Vue  -->
    <script type="text/javascript" src="../js/vue.js"></script>
    <style>
      .base {
        padding: 5px;
        height: 100px;
      }
    </style>
  </head>
  <body>
    <div id="root">
      <h1>列表过滤</h1>
      <div>
        <h2>数组</h2>
        <input type="text" placeholder="请输入名称" v-model="filterName" />
        <ul>
          <!-- :key="item.id" :key="index" -->
          <li v-for="(item,index) in filterPersons" :key="item.id">
            {{index}}-{{item.id}}-{{item.name}}
          </li>
        </ul>
      </div>
    </div>
  </body>
  <script type="text/javascript">
    Vue.config.productionTip = false; // 阻止vue在启动是生成生产提示
    const vm = new Vue({
      el: "#root",
      data: {
        name: "Vue 扛把子",
        persons: [
          { id: "001", name: "刘德华", age: 18 },
          { id: "002", name: "马德华", age: 20 },
          { id: "003", name: "李小龙", age: 20 },
          { id: "004", name: "释小龙", age: 18 },
        ],
        filterName: ""
      },
      computed: {
        filterPersons(){
            console.log(" computed filterName value => " + this.filterName); 
            return this.persons.filter((item) => {
              return item.name.indexOf( this.filterName) > -1;
            });
        }
      },

      methods: {},
      watch: {
      },
    });
  </script>
</html>
  • 效果

初始化

搜索

清空

列表排序

基础环境

  • 数据
javascript 复制代码
persons: [
   { id: "001", name: "刘德华", age: 19 },
   { id: "002", name: "马德华", age: 20 },
   { id: "003", name: "李小龙", age: 21 },
   { id: "004", name: "释小龙", age: 18 },
 ]
  • 根据 年龄排序

计算属性

  • 代码
javascript 复制代码
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <title>列表过滤</title>
    <!--  引入Vue  -->
    <script type="text/javascript" src="../js/vue.js"></script>
    <style>
      .base {
        padding: 5px;
        height: 100px;
      }
    </style>
  </head>
  <body>
    <div id="root">
      <h1>列表过滤</h1>
      <div>
        <h2>数组</h2>
        <input type="text" placeholder="请输入名称" v-model="filterName" />
        <button @click="sortType='desc'">年龄逆序</button>
        <button @click="sortType='asc'">年龄正序</button>
        <button @click="sortType=''">年龄原序</button>
        <ul>
          <!-- :key="item.id" :key="index" -->
          <li v-for="(item,index) in filterPersons" :key="item.id">
            {{index}}-{{item.id}}-{{item.name}}-{{item.age}}
          </li>
        </ul>
      </div>
    </div>
  </body>
  <script type="text/javascript">
    Vue.config.productionTip = false; // 阻止vue在启动是生成生产提示
    const vm = new Vue({
      el: "#root",
      data: {
        name: "Vue 扛把子",
        persons: [
          { id: "001", name: "刘德华", age: 19 },
          { id: "002", name: "马德华", age: 20 },
          { id: "003", name: "李小龙", age: 21 },
          { id: "004", name: "释小龙", age: 18 },
        ],
        filterName: "",
        sortType: ""
      },
      computed: {
        filterPersons() {
          console.log("computed filterName value => " + this.filterName);
          const arr = this.persons.filter((item) => {
            return item.name.indexOf(this.filterName) > -1;
          });
          if (this.sortType !== "") {
            console.log("computed sortType value => " + this.sortType);
            arr.sort((v1, v2) => {
              return this.sortType === "asc" ? v1.age - v2.age : v2.age - v1.age;
            });
          }
          return arr;
        },
      },

      methods: {},
      watch: {},
    });
  </script>
</html>
  • 效果

初始化 不排序

年龄逆序

年龄正序

年龄原序

过滤 & 年龄正序

过滤 & 年龄逆序

相关推荐
Harriet嘉13 小时前
vscode结合code buddy 和figma还原UI设计稿
vue·figma
木斯佳2 天前
前端八股文面经大全:阿里云AI应用开发二面(2026-03-21)·面经深度解析
前端·css·人工智能·阿里云·ai·面试·vue
工业互联网专业3 天前
基于Python的黑龙江旅游景点数据分析系统的实现_flask+spider
python·flask·vue·毕业设计·源码·课程设计·spider
大叔_爱编程3 天前
基于协同过滤算法的理财产品推荐系统-flask
python·flask·vue·毕业设计·源码·课程设计·协同过滤
小彭努力中3 天前
193.Vue3 + OpenLayers 实战:圆孔相机模型推算卫星拍摄区域
vue.js·数码相机·vue·openlayers·geojson
小彭努力中3 天前
192.Vue3 + OpenLayers 实战:点击地图 Feature,列表自动滚动定位
vue·webgl·openlayers·geojson·webgis
百锦再3 天前
Vue不是万能的:前后端不分离开发的优势
前端·javascript·vue.js·前端框架·vue
BUG创建者4 天前
openlayers上跟据经纬度画出轨迹
开发语言·javascript·vue·html
ん贤4 天前
首屏优化实践:如何将 Vue3 + Vite 项目的加载速度提升3倍
性能优化·vue·vite
A_nanda4 天前
一款前端PDF插件
前端·学习·pdf·vue