若依前端vue实现 输入框下拉选择加搜索用户

wutonglamp 2024-08-04 10:33:01 阅读 55

探索代码以及详细的注解

<code><template>

<div>

<el-select v-model="selectedUserId" filterable placeholder="选择用户" @change="handleChange">code>

<el-option

v-for="user in filteredUsers"code>

:key="user.userId"code>

:label="user.nickName + ' (' + user.email + ')'"code>

:value="user.userId">code>

</el-option>

</el-select>

</div>

</template>

<el-select>: 这是 Element Plus 组件库中的下拉选择框组件。它具有几个 Vue 特有的属性:

v-model="selectedUserId":在 selectedUserId 上创建双向绑定。从下拉框选择的任何项将更新此变量,且 selectedUserId 的任何更新将影响所选项。code>

filterable:使下拉框具有搜索功能,用户可以输入文本来过滤选项。

placeholder="选择用户":在下拉框为空时显示的占位文本。code>

@change="handleChange":绑定一个事件监听器,当选项变化时,调用 handleChange 函数。code>

<el-option>: 循环渲染每个用户为一个选项。

v-for="user in filteredUsers":对 filteredUsers 数组进行遍历,每个元素渲染一个 <el-option>。code>

:key="user.userId":为每个渲染的 DOM 元素提供一个唯一键,Vue 使用这个键进行高效的 DOM 更新。code>

:label="user.nickName + ' (' + user.email + ')' ":设置下拉选项的显示文本,这里使用了用户的昵称和电子邮件。code>

:value="user.userId":设置当此选项被选中时,v-model 绑定的 selectedUserId 更新的值。code>

<script setup>

import { ref, computed, onMounted } from 'vue'

import { ElSelect, ElOption } from 'element-plus'

import { getUser } from '@/api/hg/test' // 确保路径正确

// 使用 ref 创建响应式变量

//存储用户列表

const users = ref([])

//选中的用户id

const selectedUserId = ref(null)

const query = { } // 可以添加需要的查询参数

// API 请求加载用户

async function fetchUsers() {

const response = await getUser(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()

})

// 监听选择变化并输出到控制台来查看选择的变化

function handleChange(value) {

console.log("Selected user ID:", value)

}

</script>

<style scoped>

/* 可以添加一些 CSS 样式 */

</style>

功能已实现(可以实时的搜索并选择人员)!

在这里插入图片描述



声明

本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。