上周又又又又加需求了,好吧,bring it on
先讲需求目标要实现功能
- focus的时候要出历史搜索(要存缓存)
- 历史搜索下部出现清除缓存按钮
- input的时候要根据后台返回出提词
elementui中比较能用的上就是 el-autocomplete 这个组件,但是呢,组件中要添加清除按钮,这个是比较麻烦的。因为,el-autocomplete 这个东西的slot是写弹框的每一项,而不是弹框整体,所以,这里我是把清空缓存的按钮作为一个选项push到提词数组之中的,然后再对该项进行样式处理;其次根据输入匹配提词,用的会是watch检测,而不是input或change事件
先上html部分
<el-autocomplete ref="input1" hide-loading class="inline-input" v-model="search_word" :fetch-suggestions="querySearch" placeholder="请输入内容">
<template slot-scope="{ item }">
<div @click.stop="goSearch(item.value)" :class="item.value === '清空历史搜索'?'clearStorage':''">{
{ item.value }}<