若依前端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>
功能已实现(可以实时的搜索并选择人员)!
声明
本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。