el-select 搜索无选项时 请求接口添加输入的值

news2025/1/10 16:08:18

el-select 搜索无选项时 请求接口添加输入的值

<template>
	<div class="flex">
		<el-select class="w250" v-model="state.brand.id" placeholder="请选择"  clearable             
           filterable :filter-method="handleQuery" @change="tagHandler">
			<el-option v-for="item in state.tableData" :key="item.id"            
                :label="item.displayName" :value="item.id">
			</el-option>
			<template #empty>
				<div class="add-item">
					<span class="add-item-value" @click="addBrand">
					     <el-icon><Plus /></el-icon>添加 
                         <span class="searchValue">{{ state.searchValue }}</span>
					</span>
				</div>
			</template>
		</el-select>
	</div>
</template>
<script setup lang="ts">
import { reactive, onMounted } from 'vue';
const state = reactive({
    // 品牌的数据结构
	brand: {
		id: undefined,
		displayName: '',
	},
    // 全部的选项
	tableData: [] as any,
    // 存放输入的值
	searchValue: '',
});

onMounted(() => {
    // 初始请求一次全部选项
	handleQuery('');
});

// 选择以后清空选择框的输入值
const tagHandler = () => {
	state.searchValue = '';
};

// 输入值开始搜索
const handleQuery = async (e: any) => {
    // 把输入的值存起来
	state.searchValue = e;
	let res = await getAPI(ProductExtApi);
	state.tableData = res.data.result?.items ?? [];
};


// 添加品牌
const addBrand = async () => {
    // 请求添加接口
	let res = await getAPI(BrandApi)({
		displayName: state.searchValue,
	});

    // 接口返回ID 赋值到我们自定义的数据上面
	state.brand = {
		id: res.data.result ?? 0,
		displayName: state.searchValue,
	};

    // 添加完执行一次搜索
	if (res.data.code == 200) handleQuery(state.searchValue);
	state.searchValue = '';
};

// 组件初始化赋值
const set = (brand: any) => {
	if (brand) {
		if (!state.tableData.find((el: any) => el.id == brand.id)) {                
            state.tableData.push(brand);
        }
		state.brand = brand;
	}
};

// 返回给需要的组件
const get = () => {
	return state.brand.id;
};

defineExpose({ set, get });
</script>

<style lang="scss" scoped>

.add-item {
	padding: 10px;
	font-size: 14px;

	.add-item-value {
		cursor: pointer;
	}

	i {
		vertical-align: text-top;
		margin-right: 5px;
	}

	.searchValue {
		color: var(--el-color-primary);
		margin-left: 5px;
	}
}</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1170940.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

关闭Dell xps 系列笔记本触控屏

【电脑】->【管理】->【设备管理器】 右键 禁用选择即可

怎么测量直线模组的精度?

直线模组是一款比较多变的一种产品&#xff0c;适合多种行业&#xff0c;同时它也适合比较多的环境&#xff0c;是一种比较全面的直线运动的装置。直线模组是非常精密的自动化机械设备&#xff0c;在实践中&#xff0c;应该要严格把握具体精度&#xff0c;并且在必要的时候&…

CDN加速是否对SEO有正面影响

当谈到网站性能优化和SEO&#xff08;搜索引擎优化&#xff09;时&#xff0c;CDN&#xff08;内容分发网络&#xff09;加速无疑是一个重要的话题。CDN是一种分布式网络基础设施&#xff0c;它通过将网站内容分发到全球各地的边缘服务器&#xff0c;从而加速内容的传递。在这篇…

apb介绍

https://www.cnblogs.com/xianyuIC/p/17279209.html***带testbench https://zhuanlan.zhihu.com/p/623829190?utm_id0 https://zhuanlan.zhihu.com/p/607964532带testbench by四人独行 https://blog.csdn.net/weixin_40377195/article/details/124899571 APB是最简单的AMBA总…

链表详讲(附代码)

1.什么是链表 链表是一种非常常见的数据结构&#xff0c;在程序设计中经常被使用。它由一系列节点组成&#xff0c;每个节点都有用来存放数据的数据区以及存放下一个节点地址指针的地址区。跟顺序表不同的是&#xff0c;链表的节点之间的空间并非是连续的&#xff0c;依靠地址区…

最新waymo数据集 百度网盘

最新waymo数据集介绍 waymo数据集是有史以来最大&#xff0c;最多样化的自动驾驶数据集&#xff0c;包含 传感器数据边界框数据2D视频全景分割标签关键点标签3D语义分割标签2D和3D边界框的关联 是该领域质量最高、规模最大的数据集之一&#xff0c;用于帮助研究界在机器感知…

【Orangepi Zero2 全志H616】开发板资料(刷机、系统烧录)及环境搭建

一、资料文档 二、MobaXterm远程连接工具 三、修改登录密码 四、修改内核日志等级 五、配置网络 六、SSH 访问 OrangePi ZERO 2 七、配置 vim 八、基于官方外设开发SDK 一、资料文档 官网资料下载 GitHub&#xff1a;新版本的 orangepi-build 源码 环境搭建&#xff1a;新手配…

IP协议汇总

IP协议 1.基本概念 IP协议全称为“网际互连协议&#xff08;Internet Protocol&#xff09;” ,IP协议是TCP/IP体系中的网络层协议。 总的来说&#xff0c;IP协议的最重要功能是提供了一种标准化的方式来路由和传输数据包&#xff0c;以实现全球互联网上的通信。 &#xff…

YOLOv7独家原创改进:新颖自研设计的BSAM注意力,基于CBAM升级

💡💡💡本文全网首发独家改进:提出新颖的注意力BSAM(BiLevel Spatial Attention Module),创新度极佳,适合科研创新,效果秒杀CBAM,Channel Attention+Spartial Attention升级为新颖的 BiLevel Attention+Spartial Attention 1)作为注意力BSAM使用; 推荐指数:…

数据结构构之顺序表

1.线性表 线性表&#xff08;linear list&#xff09;是n个具有相同特性的数据元素的有限序列。 线性表是一种在实际中广泛使用的数据结构&#xff0c;常见的线性表&#xff1a;顺序表、链表、栈、队列、字符串... 线性表在逻辑上是线性结构&#xff0c;也就说是连续的一条直线…

【halcon踩坑】区域为空但个数是1

背景 我在做瑕疵检测的时候&#xff0c;通过计算瑕疵区域的个数&#xff08;count_obj&#xff08;&#xff09;&#xff09;是否为0&#xff0c;来判断是否有瑕疵&#xff0c;如果不为0&#xff0c;那边我就会在图片上标记这个瑕疵的位置&#xff01; 但是有一次我发现明明没…

山西电力市场日前价格预测【2023-11-05】

日前价格预测 预测说明&#xff1a; 如上图所示&#xff0c;预测明日&#xff08;2023-11-05&#xff09;山西电力市场全天平均日前电价为192.40元/MWh。其中&#xff0c;最高日前电价为374.84元/MWh&#xff0c;预计出现在04:15。最低日前电价为0.00元/MWh&#xff0c;预计出…

史上最详细的八大排序讲解(错过绝对后悔系列)建议先收藏再观看!—— 数据结构

&#x1f636;‍&#x1f32b;️Take your time ! &#x1f636;‍&#x1f32b;️ &#x1f4a5;个人主页&#xff1a;&#x1f525;&#x1f525;&#x1f525;大魔王&#x1f525;&#x1f525;&#x1f525; &#x1f4a5;代码仓库&#xff1a;&#x1f525;&#x1f525;魔…

DB-GPT介绍

DB-GPT介绍 引言DB-GPT项目简介DB-GPT架构关键特性私域问答&数据处理多数据源&可视化自动化微调Multi-Agents&Plugins多模型支持与管理隐私安全支持数据源 子模块DB-GPT-Hub微调参考文献 引言 随着数据量的不断增长和数据分析的需求日益增多&#xff0c;将自然语言…

Docker 从 安装 到 配置 到 实战:手把手带你入门

文章目录 前言什么是docker&#xff1f;&#xff01;docker的作用是什么&#xff1f;&#xff01; 一、下载docker1.卸载docker2.安装yum环境3.更新yum本地软件源4.安装Docker&#xff08;参数ce&#xff1a;社区版&#xff09;5.Docker使用中会涉及到各种端口&#xff0c;为了…

为什么小程序做好了,却运营不起来?

​在小程序开发完成并投入市场后&#xff0c;许多商家发现小程序虽然做得很精美&#xff0c;但是却无法吸引到足够的用户&#xff0c;更谈不上留住用户了。那么&#xff0c;为什么小程序做好了却运营不起来呢&#xff1f;本文将就此问题进行探讨。 一、缺乏运营策略 很多商家在…

0002Java安卓程序设计-springboot合同管理APP论文

文章目录 摘 要目 录系统设计开发环境 摘 要 随着互联网趋势的到来&#xff0c;各行各业都在考虑利用互联网将自己推广出去&#xff0c;最好方式就是建立自己的互联网系统&#xff0c;并对其进行维护和管理。在现实运用中&#xff0c;应用软件的工作规则和开发步骤&#xff0c…

在Spring Boot中使用国产数据库连接池Druid

在我们实际开发过程中&#xff0c;我们经常使用的是DriverManager来获取&#xff0c;通过每次都向数据库建立连接时将Connection加载到内存中&#xff0c;然后验证用户名和密码&#xff0c;这段时间的消耗大致在0.0 5s - 1s左右&#xff0c;每次当我们需要获取数据库连接的时候…

“利用自动粘贴功能,一键粘贴网址,提升工作效率“

在快节奏的现代工作中&#xff0c;效率是关键。如果你经常需要复制和粘贴网址&#xff0c;那么你可能会浪费很多时间。幸运的是&#xff0c;我们的自动粘贴功能可以帮助你自动粘贴网址&#xff0c;一键即可完成&#xff0c;让你更加高效地工作。 首先&#xff0c; 我们要进入首…

操作系统复习(1)概述

一、序言 1.1简介 计算机系统组成&#xff1a;硬件操作系统 操作系统是计算机系统中的一个重要组成部分&#xff0c;它负责管理和控制计算机的硬件资源和软件资源&#xff0c;以及提供用户接口和其他功能 操作系统定义&#xff1a;操作系统是计算机系统中的一个系统软件&…