探索代码以及详细的注解
<template><div><el-select v-model="selectedUserId" filterable placeholder="选择用户" @change="handleChange"><el-option
v-for="user in filteredUsers":key="user.userId":label="user.nickName + ' (' + user.email + ')'":value="user.userId"></el-option></el-select></div></template><el-select>: 这是 Element Plus 组件库中的下拉选择框组件。它具有几个 Vue 特有的属性:
v-model="selectedUserId":在 selectedUserId 上创建双向绑定。从下拉框选择的任何项将更新此变量,且 selectedUserId 的任何更新将影响所选项。
filterable:使下拉框具有搜索功能,用户可以输入文本来过滤选项。
placeholder="选择用户":在下拉框为空时显示的占位文本。
@change="handleChange":绑定一个事件监听器,当选项变化时,调用 handleChange 函数。
<el-option>: 循环渲染每个用户为一个选项。
v-for="user in filteredUsers":对 filteredUsers 数组进行遍历,每个元素渲染一个 <el-option>。
:key="user.userId":为每个渲染的 DOM 元素提供一个唯一键,Vue 使用这个键进行高效的 DOM更新。:label="user.nickName + ' (' + user.email + ')' ":设置下拉选项的显示文本,这里使用了用户的昵称和电子邮件。:value="user.userId":设置当此选项被选中时,v-model 绑定的 selectedUserId 更新的值。
<script setup>import{ ref, computed, onMounted }from'vue'import{ ElSelect, ElOption }from'element-plus'import{ getUser }from'@/api/hg/test'// 确保路径正确// 使用 ref 创建响应式变量//存储用户列表const users =ref([])//选中的用户idconst selectedUserId =ref(null)const query ={}// 可以添加需要的查询参数// API 请求加载用户asyncfunctionfetchUsers(){const response =awaitgetUser(query)if(response.code ===200){
users.value = response.rows
}else{
console.error('Failed to fetch users:', response.msg)}}// 计算属性,用于实时搜索筛选//这个计算属性直接返回用户列表users引用的值,users是一个响应式引用,存储从后端API获取的用户列表//由于计算属性依赖于users的值,所以每当users更新时,filteredUsers也会自动更新。实现实时搜索const filteredUsers =computed(()=>{return users.value
})// 监听组件加载onMounted(()=>{fetchUsers()})// 监听选择变化并输出到控制台来查看选择的变化functionhandleChange(value){
console.log("Selected user ID:", value)}</script><style scoped>/* 可以添加一些 CSS 样式 */</style>
功能已实现(可以实时的搜索并选择人员)!
本文转载自: https://blog.csdn.net/qq_45765384/article/details/139138841
版权归原作者 wutonglamp 所有, 如有侵权,请联系我们删除。
版权归原作者 wutonglamp 所有, 如有侵权,请联系我们删除。