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 处理逻辑分离,展示了如何在状态更新后进行额外的操作。

相关推荐
毕设源码-朱学姐13 分钟前
【开题答辩全过程】以 基于vue.js的校园二手平台为例,包含答辩的问题和答案
前端·javascript·vue.js
m0_4711996327 分钟前
【JavaScript】Set 和 Map 核心区别与实战用法(ES6 集合全解析)
前端·javascript·es6
小白|1 小时前
【OpenHarmony × Flutter】混合开发性能攻坚:如何将内存占用降低 40%?Flutter 引擎复用 + ArkTS 资源回收实战指南
开发语言·javascript·flutter
和和和1 小时前
React Scheduler为何采用MessageChannel调度?
前端·javascript
momo061171 小时前
用一篇文章带你手写Vue中的reactive响应式
javascript·vue.js
他是龙5511 小时前
第29天:安全开发-JS应用&DOM树&加密编码库&断点调试&逆向分析&元素属性操作
开发语言·javascript·安全
和和和2 小时前
前端应该知道的浏览器知识
前端·javascript
树深遇鹿2 小时前
数据字典技术方案实战
前端·javascript·架构
爱吃大芒果2 小时前
Flutter 基础组件详解:Text、Image、Button 使用技巧
开发语言·javascript·flutter·华为·ecmascript·harmonyos
大布布将军2 小时前
一种名为“Webpack 配置工程师”的已故职业—— Vite 与“零配置”的快乐
前端·javascript·学习·程序人生·webpack·前端框架·学习方法