个人技术分享

探索代码以及详细的注解

<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([])
//选中的用户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>

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

在这里插入图片描述