react通过onChange传输select的value数据

js 复制代码
     <Select
        label="Target parking space"
        checkIconPosition="right"
        placeholder="choose a parking space"
        value={targetParkingSpace}
        searchable
        onChange={store.getState().setTargetParkingSpace}
        data={parkingSpaceTrackIdList}
      />
      <Select
js 复制代码
setTargetParkingSpace: (id) => {
        Subjects.TargetParkingSlotChanged.next({
          prev: get().simulationSettings.target_parking_space_id,
          next: id,
        });
        set(
          produce((state) => {
            state.simulationSettings.target_parking_space_id = id;
          })
        );
      },

当 Select 组件的选项变更时,如果组件本身就是设计为直接传递新的值(在这种情况下是选定的车位 ID)给 onChange 回调函数,那么便不需要从事件对象中提取该值。在你的代码中,store.getState().setTargetParkingSpace 准备好接收该 ID,并且被用作 onChange 的回调。

复制代码
<Select
  ...
  onChange={store.getState().setTargetParkingSpace}
  ...
/>

在这种情况下,Select 组件内部会直接调用 store.getState().setTargetParkingSpace 并传递选定的 ID 作为参数。因此,即使没有明确地写出 (value) => ... 这样的箭头函数,onChange 事件也能够成功工作并且传递 ID。

这种行为意味着 Select 组件的实现方式是预期其 onChange 属性将一个值传递给回调函数,而不是传递一个完整的事件对象。这在一些UI库中很常见,尤其是那些旨在简化表单处理的库。

代码示例中的剩余部分提供了关于如何使用 produce 函数(来自Immer库)更新状态以及通过 RxJS Subject 发送通知的方法。这部分与直接的 onChange 处理逻辑分离,展示了如何在状态更新后进行额外的操作。

相关推荐
kyriewen6 小时前
用了半年 Claude Code 后,我尝试关掉它写了一周代码——结果比想象中严重
前端·javascript·ai编程
山河木马8 小时前
矩阵专题0-webGL中的矩阵
javascript·webgl·计算机图形学
Asize9 小时前
多模态生图:从 Vite 工程化到前端调用 Qwen Image
javascript·人工智能·后端
陳陈陳9 小时前
从Token到Embedding:一篇文章搞懂大模型的「文字数学变形记」
前端·javascript·ai编程
用户938515635079 小时前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
橘子星9 小时前
LLM 无状态架构实践:从原理到代码落地
前端·javascript·人工智能
To_OC10 小时前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
风止何安啊11 小时前
网课倍速痛点解决:一套前端代码实现自由控速播放器
前端·javascript·node.js
光影少年12 小时前
原生DOM操作在React 中的注意事项
前端·javascript·react.js
糖拌西瓜皮12 小时前
Node.js核心模块实战:文件、路径、HTTP与流处理
javascript·node.js