VueJS实现模糊查询

原文请查看公共号

 

 

 

前置条件:

  1. 开发环境:windows

  2. 开发框架:vue2.5 ,vue-cli 4.0+

  3. 编辑器:HbuilderX

  4.  兼容版本:vue2.5     Chrome 99.0.4844.51

     

正文:实现此功能需要用到JS的 filter, includes两个API ,具体使用方法,童鞋们自行百度,不再一 一赘述

 

打开控制台,可以看到选中的数组

 

上热乎乎的代码:

 

<template>
  <div id="app">
    <input type="text" v-model="input" />
    <ul>
      <li v-for="item of search"
        :key="item.name"
        @click="selection(item)"
      >{{item.name}}</li>
    </ul>
  </div>
</template>

<script>
export default {
  name: "app",
  data() {
    return {
      items: [
        { name: "路飞" ,id:2},
        { name: "索隆" ,id:3 },
        { name: "路也" ,id:4 },
        { name: "娜美" ,id:5 },
        { name: "山本" ,id:6 },
        { name: "美了" ,id:7 },
        { name: "乔治山本路夫" ,id:8 },
        { name: "美杜莎" ,id:1 },
        { name: "娜美尼可" ,id:9 }
      ],
      input: ""
    };
  },
  methods:{
    selection(data){
      console.log("选中的数据:",data);
    }
  },
  computed: {
    search() {
      if (!this.input) {
        return this.items;
      }
      return this.items.filter(v => {
        return v.name.includes(this.input);
      });
    }
  }
};
</script>

 

Ps:因为要对数组进行过滤,使用 filter 填充所有通过测试的数组,而 

includes  方法确定数组是否包含指定的元素,返回布尔值;如果返会true,说明存在符合条件的数组,filter 会自动筛选出来与条件相匹配的数据,并自动返回

posted @ 2022-03-25 13:54  白墨阳  阅读(34)  评论(0编辑  收藏  举报