el-autocomplete |element-ui中的input实现模糊搜索

此处只写方法部分

        <el-autocomplete
          class="inline-input"
          v-model="queryParams.companyName"
          :fetch-suggestions="querySearch"
          placeholder="请输入内容"
          :trigger-on-focus="false"
          //选中查询时间
          @select="handleQuery"
          //回车查询事件
          @keyup.enter.native="handleQuery"
        ></el-autocomplete>

    querySearch(queryString, cb) {
      let queryCompanyNameList = this.queryCompanyNameList;
      let results = queryString ? queryCompanyNameList.filter(this.createFilter(queryString)) : queryCompanyNameList;
      // 调用 callback 返回建议列表的数据
      console.log('// 调用 callback 返回建议列表的数据',results)
      cb(results);
    },
    createFilter(queryString) {
      return (item) => {
        return item.value.toUpperCase().match(queryString.toUpperCase());
        //下面注释部分:我这里用的是调用match方法,是模糊匹配;官方调用的是indexOf,是精确匹配,看自身情况选择
        //return (item.value.toLowerCase().indexOf(queryString.toLowerCase()) === 0);
      };
    },

学习自:https://blog.csdn.net/fenger_c/article/details/108572690

上一篇:HTTP请求与响应处理


下一篇:vbs