在Vue.js中,可以通过扩展现有的el-autocomplete
组件来创建自定义的自动补全组件。以下是一个简单的示例,展示了如何基于Element UI的el-autocomplete
组件创建一个自定义的自动补全组件sgAutocomplete
:
<template>
<el-autocomplete
v-model="value"
:fetch-suggestions="querySearch"
:placeholder="placeholder"
@select="handleSelect"
></el-autocomplete>
</template>
<script>
export default {
name: 'sgAutocomplete',
props: {
// 接收外部传入的值
value: {
type: String,
default: ''
},
// 占位符
placeholder: {
type: String,
default: '请输入内容'
},
// 这里可以添加更多需要的props
},
methods: {
querySearch(queryString, cb) {
// 模拟从后端获取数据的异步操作
setTimeout(() => {
// 模拟的数据源,实际应用中应该从服务端获取
let suggestions = ['One', 'Two', 'Three'];
// 模拟查询过程中对数据的处理,例如过滤
suggestions = suggestions.filter(item => {
return item.toLowerCase().indexOf(queryString.toLowerCase()) !== -1;
});
// 调用 callback 返回建议列表的数据
cb(suggestions);
}, 500 * Math.random()); // 模拟随机的异步加载时间
},
handleSelect(item) {
// 当选中建议项时触发,这里可以执行一些自定义的逻辑
this.$emit('select', item);
}
}
};
</script>
在父组件中使用sgAutocomplete
时,你可以像使用任何其他Vue组件一样:
<template>
<div>
<sgAutocomplete v-model="autocompleteValue" placeholder="请输入关键字"></sgAutocomplete>
</div>
</template>
<script>
import sgAutocomplete from './path/to/sgAutocomplete.vue';
export default {
components: {
sgAutocomplete
},
data() {
return {
autocompleteValue: ''
};
}
};
</script>
这个自定义组件sgAutocomplete
接收一个value
prop用于双向绑定输入值,并且定义了一个名为querySearch
的方法来模拟从后端获取数据,并处理成el-autocomplete
组件需要的格式。同时,它也定义了一个方法handleSelect
来处理选中建议项的逻辑。在父组件中,你可以通过v-model
来绑定输入的值,并通过props传递占位符等需要的配置。