Element-ui Select选择器自定义搜索方法

效果图

在这里插入图片描述

具体实现

<template><div class="home"><el-selectref="currencySelect"v-model="currency"filterable:spellcheck="false"placeholder="请选择":filter-method="handleCurrencyFilter"@change="handleCurrencyChange"@visible-change="handleCurrencyVisible"style="width: 240px;"><el-optionv-for="(item, index) in currencyOptions":key="index":label="item.label":value="item.label"><span style="float: left">{{ item.label }}</span><spanv-if="item.value !== ''"style="float: right; color: #8492a6; font-size: 13px;margin-left: 15px;">{{ item.nation }}</span></el-option></el-select></div>
</template><script setup>
import { ref, reactive, computed, onMounted } from "vue"
let currency = ref('')
let currencyOld = ref('')
let flag = ref(false)
const currencySelect = ref(null)
let dataList = reactive([{ label: 'CNY', value: 'CNY', nation: '中国'},{ label: 'USD', value: 'USD', nation: '美国'},{ label: 'EUR', value: 'EUR', nation: '欧盟'},{ label: 'JPY', value: 'JPY', nation: '日本'},{ label: 'GBP', value: 'GBP', nation: '英国'},{ label: 'AUD', value: 'AUD', nation: '澳大利亚'},{ label: 'CHF', value: 'CHF', nation: '瑞士'},{ label: 'CAD', value: 'CAD', nation: '加拿大'},{ label: 'NZD', value: 'NZD', nation: '新西兰'},{ label: 'SGD', value: 'SGD', nation: '新加坡'},{ label: 'HKD', value: 'HKD', nation: '香港'},{ label: 'TWD', value: 'TWD', nation: '台湾'},{ label: 'SEK', value: 'SEK', nation: '瑞典'},{ label: 'DKK', value: 'DKK', nation: '丹麦'},{ label: 'NOK', value: 'NOK', nation: '挪威'},{ label: 'HUF', value: 'H}UF', nation: '匈牙利'},{ label: 'PLN', value: 'PLN', nation: '波兰'},{ label: 'RUB', value: 'RUB', nation: '俄罗斯'},{ label: 'BRL', value: 'BRL', nation: '巴西'},{ label: 'MXN', value: 'MXN', nation: '墨西哥'},{ label: 'ZAR', value: 'ZAR', nation: '南非'},{ label: 'TRY', value: 'TRY', nation: '土耳其'},{ label: 'INR', value: 'INR', nation: '印度'},{ label: 'IDR', value: 'IDR', nation: '印度尼西亚'},{ label: 'MYR', value: 'MYR', nation: '马来西亚'},{ label: 'PHP', value: 'PHP', nation: '菲律宾'},{ label:'THB', value: 'THB', nation: '泰国'},{ label: 'KRW', value: 'KRW', nation: '韩国'},{ label: 'VND', value: 'VND', nation: '越南'},{ label: 'HKD', value: 'HKD', nation: '香港'},{ label: 'KPW', value: 'KPW', nation: '朝鲜'}
])
let currencyOptions = ref([])const getData = () => {currencyOptions.value = dataList
}
// 自定义搜索方法
const handleCurrencyFilter = (query) => {// 如果搜索关键字为空,则恢复搜索前的值currency.value = query ? query : currencyOld.valuecurrencyOptions.value = dataList.filter(v => {return v.label.indexOf(query.toUpperCase()) > -1 || v.nation.indexOf(query) > -1})
}
// 选中值发生变化时触发
const handleCurrencyChange = (val) => {flag.value = truecurrencyOld.value = valcurrencySelect.value.blur()// 延时,避免搜索后下拉列表恢复全量数据时高度闪现setTimeout(() => {currencyOptions.value = [...dataList]}, 150)
}
// 下拉框出现/隐藏时触发
const handleCurrencyVisible = (visible) => {if (!visible) {// 下拉框隐藏时, 如果没有选择新的值则恢复搜索前的值if (!flag.value) currency.value = currencyOld.valuecurrencySelect.value.blur()} else {flag.value = false}
}
onMounted(() => {getData()
})
</script>
<style scoped lang="less">
.home {display: flex;justify-content: center;
}
</style>

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JS的学习与使用

JS的学习与使用 一 什么是Javascript&#xff1f; Javascript是一门跨平台&#xff0c;面向对象的脚本语言&#xff0c;是用来控制网页行为的&#xff0c;它能使网页可以交互 java与Javascript是完全不同的语言&#xff0c;不论是概念还是设计&#xff0c;但是基础语法类似 E…

Docker:查看镜像里的文件

目录 背景步骤1、下载所需要的docker镜像2、创建并运行临时容器3、停止并删除临时容器 背景 在开发过程中&#xff0c;为了更好的理解和开发程序&#xff0c;有时需要确认镜像里的文件是否符合预期&#xff0c;这时就需要查看镜像内容 步骤 1、下载所需要的docker镜像 可以使…

【网络安全 | 漏洞挖掘】通过密码重置污染实现账户接管

未经许可,不得转载。 文章目录 密码重置污染攻击漏洞挖掘的过程目标选择与初步测试绕过 Cloudflare 的尝试发现两个域名利用 Origin 头部污染实现账户接管攻击流程总结在今天的文章中,我们将深入探讨一种 账户接管 漏洞,并详细分析如何绕过 Cloudflare 的保护机制,利用密码…

Redis 5 种基本数据类型详解

Redis 共有 5 种基本数据类型&#xff1a;String&#xff08;字符串&#xff09;、List&#xff08;列表&#xff09;、Set&#xff08;集合&#xff09;、Hash&#xff08;散列&#xff09;、Zset&#xff08;有序集合&#xff09;。 这 5 种数据类型是直接提供给用户使用的&…

AI 提示词(Prompt)入门 十:最佳实践|详细询问,提供细节!

1、原则解释 当与 ChatGPT 交流时&#xff0c;提供具体和详细的信息非常重要。 这样做可以帮助 ChatGPT 更准确地理解你的需求和上下文&#xff0c;从而生成更相关和有用的回答 明确的信息可以包括具体的问题背景、相关领域的说明、你所期望的答案类型等。 2、如何实践 明…

数据库的隔离机制---对MySQL 默认隔离级别的理解

参考&#xff1a; 脏读、幻读和不可重复读_脏读 ​​​​​​ 全网最详细MVCC讲解&#xff0c;一篇看懂 - 知乎全网最详细MVCC讲解&#xff0c;一篇看懂 - 知乎 面试官&#xff1a;MySQL 的默认隔离级别是什么?可以解决幻读问题吗&#xff1f; 目录 一、脏读、幻读、不可…

UNI-APP小程序答题功能开发(左右滑动,判断,填空,问答,答题卡,纠错,做题倒计时等)

原博&#xff1a;uni-app小程序答题功能开发(左右滑动,判断,填空,问答,答题卡,纠错,做题倒计时等)_uniapp答题模板-CSDN博客 标签&#xff1a; 小程序 uni-app 模板链接:答题模板 html部分 这里没啥好说的,就是根据不同的状态显示不同的内容 <template><view>…

SpringBoot多环境配置的实现

前言 开发过程中必然使用到的多环境案例&#xff0c;通过简单的案例分析多环境配置的实现过程。 一、案例 1.1主配置文件 spring:profiles:active: prod server:port: 80801.2多环境配置文件 开发环境 blog:domain: http://localhost:8080测试环境 blog:domain: https:/…

另外一种缓冲式图片组件的用法

文章目录 1. 概念介绍2. 使用方法2.1 基本用法2.2 缓冲原理3. 示例代码4. 内容总结我们在上一章回中介绍了"FadeInImage组件"相关的内容,本章回中将介绍CachedNetworkImage组件.闲话休提,让我们一起Talk Flutter吧。 1. 概念介绍 我们在本章回中介绍的CachedNetwo…

Linux下多线程

在Linux下的底层里并没有多线程这个概念&#xff0c;取而代之的是轻量级进程的概念。应为在Llinu下内核下并没有TCB,而只有PCB。 线程是什么 在⼀个程序⾥的⼀个执⾏路线就叫做线程&#xff08;thread&#xff09;。更准确的定义是&#xff1a;线程是“⼀个进程内部 的控制序…

Win10/11 安装使用 Neo4j Community Edition

如果你下载的是 Neo4j Community Edition 的压缩包&#xff0c;意味着你需要手动解压并配置 Neo4j。以下是详细的使用步骤&#xff1a; 0. 下载压缩包 访问Neo4j官网&#xff0c;找到 Community Edition 版本并选择 4.x 或者 5.x 下载&#xff1a;https://neo4j.com/deployme…

PCB+SMT线上报价系统+PCB生产ERP系统自动化拼板模块升级

PCB生产ERP系统的智能拼版技术&#xff0c;是基于PCB前端报价系统获取到的用户或市场人员已录入系统的板子尺寸及set参数等&#xff0c;按照最优原则或利用率最大化原则自动进行计算并输出拼版样式图和板材利用率&#xff0c;提高工程人员效率&#xff0c;减少板材的浪费。覆铜…

Excel根据条件动态索引单元格范围

假如我是一个老板&#xff0c;下面有数不胜数的员工&#xff0c;我要检查他们每周的工作产出&#xff0c;列一个排行榜&#xff0c;提高员工积极性&#xff0c;毕竟多劳多得嘛。 每天去手动统计&#xff0c;未免显得不太聪明&#xff0c;我们可以利用公式来解决这个问题。 我们…

SpringBoot配置相关的内容

依赖Starter和Parent 查依赖坐标网站&#xff1a;Maven Repository: Search/Browse/Explorehttps://mvnrepository.com/ 设置配置文件 配置文件相关的配置 yml多个数据的书写 配置文件的读取

机器学习-37-对ML的思考之机器学习发展的三个阶段和驱动AI发展三驾马车的由来

文章目录 1 引言2 机器学习发展的三个阶段2.1 萌芽期(20世纪50年代)2.1.1 达特茅斯会议(人工智能诞生)2.1.2 机器学习名称的由来2.2 知识期(20世纪80年代)2.2.1 知识瓶颈问题2.2.2 机器学习顶级会议ICML2.2.3 Machine Learning创刊2.2.4 神经网络规则抽取2.3 算法期(20世纪90年…

使用win32com将ppt(x)文件转换为pdf文件

本文来记录下如何使用win32com将ppt(x)文件转换为pdf文件 文章目录 win32com概述win32com优缺点代码实例本文小结 win32com概述 Pywin32 是一个用于与 Microsoft Windows 操作系统交互的 Python 扩展模块&#xff0c;它提供了对多个 Windows API 的访问&#xff0c;包括对 Mic…

鸿蒙实战:页面跳转

文章目录 1. 实战概述2. 实现步骤2.1 创建项目2.2 准备图片素材2.3 编写首页代码2.4 创建第二个页面 3. 测试效果4. 实战总结 1. 实战概述 实战概述&#xff1a;本实战通过ArkUI框架&#xff0c;在鸿蒙系统上开发了一个简单的两页面应用。首页显示问候语和“下一页”按钮&…

uniapp微信小程序接入airkiss插件进行WIFI配网

本文可参考uniapp小程序插件 一.申请插件 微信公众平台设置页链接&#xff1a;微信公众平台 登录您的小程序微信公众平台&#xff0c;进入设置页&#xff0c;在第三方设置->插件管理->添加插件中申请AiThinkerAirkissforWXMini插件&#xff0c;申请的插件appId为【wx6…

django解决跨域问题

django解决跨域问题 第一步 查看自己的 django 依赖里面有没有 django-cors-headers 包 直接 cmd pin list第二步如果没有 在自己的 pycharm 里面安装 django-cors-headers 包 pip install django-cors-headers第三步检查是否安装成功 查看自己的 django-cors-headers 安…

【51单片机】LCD1602液晶显示屏

学习使用的开发板&#xff1a;STC89C52RC/LE52RC 编程软件&#xff1a;Keil5 烧录软件&#xff1a;stc-isp 开发板实图&#xff1a; 文章目录 LCD1602存储结构时序结构 编码 —— 显示字符、数字 LCD1602 LCD1602&#xff08;Liquid Crystal Display&#xff09;液晶显示屏是…