
react 中 select 组件失焦后重置、需多次点击才生效,通常是因为未正确绑定受控状态——缺少 `value` 属性导致组件从受控变为非受控,引发渲染异常。
在 React 中,
你当前的代码中缺失了 value={difficulty},导致组件在首次选择后失去对值的控制权:React 无法追踪选中状态,浏览器回退到原生行为(如 placeholder 显示、值不持久),进而出现「失焦变回标题」「需多次点击才响应」等典型症状。
✅ 正确写法(修复版)
import { EnumDifficulty } from "@/components/Utils/EnumDifficulty";
import { useState } from "react";
const MyForm = () => {
const [difficulty, setDifficulty] = useState(undefined);
return (
Niveau
);
}; ⚠️ 注意事项
- key 不要用 uuidv4():动态生成 key 会导致每次渲染选项都重建,破坏 React 列表复用机制,可能引发闪烁或状态丢失。应使用稳定唯一值(如 diff 本身,因 EnumDifficulty 元素互异)。
- value 类型需匹配:若状态初始为 undefined,value={difficulty} 会触发 React 警告(value 不能为 undefined)。推荐统一用 value={difficulty ?? ""} 或 value={difficulty || ""},并确保 onChange 同步处理空值。
- placeholder 行为:Chakra UI 的
? 总结
Select 组件“不稳定”的根本原因,几乎总是受控性断裂——即有 onChange 却无对应 value。只要确保 value 始终反映当前状态,并为每个
云模块_YunMOK网站管理系统采用PHP+MYSQL为编程语言,搭载自主研发的模块化引擎驱动技术,实现可视化拖拽无技术创建并管理网站!如你所想,无限可能,支持创建任何网站:企业、商城、O2O、门户、论坛、人才等一块儿搞定!永久免费授权,包括商业用途; 默认内置三套免费模板。PC网站+手机网站+适配微信+文章管理+产品管理+SEO优化+组件扩展+NEW Login界面.....目测已经遥遥领先..









