首页
学习
活动
专区
圈层
工具
发布

React and redux工具包:如何添加从拖放事件中获取数据的reducer

在React和Redux工具包中处理拖放事件并更新状态,通常涉及以下几个步骤:

基础概念

Redux Toolkit: 是Redux的官方工具集,旨在简化Redux的配置和使用。 Reducer: 是一个纯函数,接收当前状态和一个动作(action),然后返回新的状态。 Drag and Drop (DnD): 是一种用户界面交互模式,允许用户通过拖动元素到另一个位置来移动或复制它们。

相关优势

  • 简化Redux使用: Redux Toolkit通过提供诸如createSlice等工具函数,减少了样板代码。
  • 提高开发效率: 自动处理不可变更新,使得状态管理更加直观。
  • 易于集成: 可以轻松地将DnD逻辑与Redux状态管理结合在一起。

类型与应用场景

  • 应用场景: 在需要用户通过拖放来重新排列列表项、上传文件或进行数据管理的应用中非常有用。
  • 类型: 可以是简单的列表排序,也可以是复杂的组件布局编辑器。

示例代码

以下是一个简单的例子,展示如何在React和Redux Toolkit中添加一个处理拖放事件的reducer。

代码语言:txt
复制
// store.js
import { configureStore } from '@reduxjs/toolkit';
import itemsReducer from './itemsSlice';

export const store = configureStore({
  reducer: {
    items: itemsReducer,
  },
});

// itemsSlice.js
import { createSlice } from '@reduxjs/toolkit';

const initialState = {
  list: ['Item 1', 'Item 2', 'Item 3'],
};

export const itemsSlice = createSlice({
  name: 'items',
  initialState,
  reducers: {
    updateOrder: (state, action) => {
      const { draggedIndex, targetIndex } = action.payload;
      const [draggedItem] = state.list.splice(draggedIndex, 1);
      state.list.splice(targetIndex, 0, draggedItem);
    },
  },
});

export const { updateOrder } = itemsSlice.actions;

// Item.js
import React from 'react';
import { useDispatch } from 'react-redux';
import { updateOrder } from './itemsSlice';

const Item = ({ item, index }) => {
  const dispatch = useDispatch();

  const handleDragStart = (e) => {
    e.dataTransfer.setData('text/plain', index);
  };

  const handleDrop = (e) => {
    e.preventDefault();
    const draggedIndex = e.dataTransfer.getData('text/plain');
    dispatch(updateOrder({ draggedIndex, targetIndex: index }));
  };

  const handleDragOver = (e) => {
    e.preventDefault();
  };

  return (
    <div
      draggable
      onDragStart={handleDragStart}
      onDrop={handleDrop}
      onDragOver={handleDragOver}
    >
      {item}
    </div>
  );
};

export default Item;

// App.js
import React from 'react';
import { useSelector } from 'react-redux';
import Item from './Item';

const App = () => {
  const items = useSelector((state) => state.items.list);

  return (
    <div>
      {items.map((item, index) => (
        <Item key={index} item={item} index={index} />
      ))}
    </div>
  );
};

export default App;

遇到问题及解决方法

问题: 拖放操作后状态没有更新。

原因: 可能是由于onDrop事件处理函数没有正确调用dispatch函数,或者updateOrder reducer没有正确实现状态更新逻辑。

解决方法: 确保onDrop事件处理函数中调用了dispatch,并且updateOrder reducer正确地使用了splice方法来更新数组。

通过以上步骤和代码示例,你应该能够在React和Redux Toolkit中实现拖放功能并更新应用状态。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

React进阶(2)-上手实践Redux-如何获取store的数据

的组合,代码就是文字描述的最佳的体现,解释 你将在本文学习到 编写Redux的的基本流程 如何获取store中公共的数据,并展示到页面上 如何更改store的公共数据,实现组件的数据与store的同步更新...组件内如何获取store中数据,通过调用getState方法获取store中的数据,该方法能够获取到store上存储的所有状态,该方法放置的位置是在constructor函数里面 this.state...进而store就获取到了reducer函数里面的组件公共存储的数据,当组件外部想要拿store的公共数据时 于是引入store,并通过getState这个函数就可以获取store中的所有数据,最终可将数据渲染到页面上...结语 本文并不是什么高大上的内容,主要是对学习Redux的一个小小的初探 用几句简单归纳下:组件如何获取store中的数据 安装redux,然后从redux中引入createStore这个方法,并调用它...,完成新旧数据的替换, 而在组件中如何获取store的数据,是通过getState方法进行获取store中的所有状态

2.6K20

React进阶(2)-上手实践Redux-如何获取store的数据

+Flux的组合,代码就是文字描述的最佳的体现,解释 你将在本文学习到 编写Redux的的基本流程 如何获取store中公共的数据,并展示到页面上 如何更改store的公共数据,实现组件的数据与store...组件内如何获取store中数据,通过调用getState方法获取store中的数据,该方法能够获取到store上存储的所有状态,该方法放置的位置是在constructor函数里面 this.state...进而store就获取到了reducer函数里面的组件公共存储的数据,当组件外部想要拿store的公共数据时 于是引入store,并通过getState这个函数就可以获取store中的所有数据,最终可将数据渲染到页面上...(都说男人只要穿上西服,就秒变男神,我双手双脚赞同) 结语 本文并不是什么高大上的内容,主要是对学习Redux的一个小小的初探 用几句简单归纳下:组件如何获取store中的数据 安装redux,然后从...这个的决定,最终该函数返回最新结果会返回给store,完成新旧数据的替换, 而在组件中如何获取store的数据,是通过getState方法进行获取store中的所有状态 那么如何保持页面的组件与store

1.8K10
  • React进阶(3)-上手实践Redux-如何改变store中的数据

    前言 在前面的一文React进阶(2)-上手实践Redux-如何获取store的数据当中,已经知道组件怎么获取store的数据,并渲染到页面上,那么在该节当中揭示怎么更改store的数据,实现页面的更新...在前文的示例代码中已经知道组件怎么从store中取数据了,然而现在,如果想要更新state的数据?怎么办?...主要开始用ant-design这个UI组件库对todolist做了一个简单的布局,然后如何将组件的数据抽离到Redux中去管理 组件如何获取Redux中store的数据,以及怎么更新store的数据的更新...纯函数,在reducer里面进行state的逻辑操作,reducer的返回值取决于state与action这个的决定,最终该函数的返回的最新结果会返回给store,完成新旧数据的替换, 而在组件中如何获取...store的数据,是通过getState方法进行获取store中的所有状态 如何保持页面的组件与store数据同步更新,需要注册订阅subscribe方法,该方法接收一个函数,在该接收的函数内触发重新获取

    2.9K30

    React进阶(3)-上手实践Redux-如何改变store中的数据

    撰文 | 川川 前言 在前面的一文React进阶(2)-上手实践Redux-如何获取store的数据当中,已经知道组件怎么获取store的数据,并渲染到页面上,那么在该节当中揭示怎么更改store的数据...(添加,删除todolist操作) 如何改变store的数据,实现页面的更新? 在前文的示例代码中已经知道组件怎么从store中取数据了,然而现在,如果想要更新state的数据?怎么办?...,其中理解Redux的工作流程是非常重要的 主要开始用ant-design这个UI组件库对todolist做了一个简单的布局,然后如何将组件的数据抽离到Redux中去管理 组件如何获取Redux中store...的数据,以及怎么更新store的数据的更新,在上文当中都有与之对应的操作和解释 用几句简单话:概括下使用Redux的流程 安装redux,然后从redux中引入createStore这个方法,并调用它,...,完成新旧数据的替换, 而在组件中如何获取store的数据,是通过getState方法进行获取store中的所有状态 如何保持页面的组件与store数据同步更新,需要注册订阅subscribe方法,该方法接收一个函数

    2.5K20

    React中的Redux

    参照 Flux 标准 Action 获取关于如何构造 action 的建议,另外还需要注意的是,我们应该尽量减少在action中传递数据。...Reducer拆分 这里我们以redux中文文档 中的todo应用为例来说明,在应用的需求中,有添加todo项,设置todo列表的过滤条件等多个action,同理我们就需要写多个reducer来描述状态是怎么改变的...而容器组件和展示组件大致有以下不同: 展示组件 容器组件 作用 描述如何展现内容、样式 描述如何运行(数据获取、状态更新) 是否能直接使用Redux 否 是 数据来源 props(属性) 监听Redux...state 数据修改 从props中调用回调函数 向Redux派发actions 调用方式 手动 通常由React Redux生成 大部分的组件都应该是展示型的,但一般需要少数的几个容器组件把它们和...所以接下来,让我们来介绍一个复杂的场景,我们来看看redux是如何应用在大型复杂充满异步事件的场景中的。 ?

    4.9K20

    React DnD

    不像其它库一样提供无穷尽的Draggable Component应对常见业务场景,React DnD从相对底层的角度提供支持,是对拖放能力的抽象与封装,通过抽象来简化使用,通过封装来屏蔽下层差异 二.术语概念...Item和Type Item是对元素/组件的抽象理解,拖放的对象不是DOM元素或React组件,而是特定数据模型(Item): An item is a plain JavaScript object...DnD就是基于Redux实现的,见下文核心实现部分 Connector Connector用来建立DOM抽象(React)与DnD Backend需要的具体DOM元素之间的联系: The connectors...source DnD Role是React DnD中的基本抽象单元: They really tie the types, the items, the side effects, and the collecting...Dispatch Action把native DnD状态传递到上层 可以看作基于Redux的逻辑拆解,中间层Core持有DnD状态,下层Backends负责实现约定的interface,作为Core的数据源

    1.6K30

    Redux

    Reducer只是一些纯函数,它接受先前的state和action,并返回新的state。 基础 Action ​ Action是把数据从应用传到store的有效载荷。...我们还需要添加一个action index字段来表示用户完成任务的动作序列号。因为数据是存放在数组中的,所以我们通过下标index哎引用特定的任务。...Redux应用中数据的声明周期遵循4个步骤: 1、调用store.dispatch(action)。 2、Redux store调用传入的reducer函数。...展示组件 容器组件 作用 描述如何展现(骨架、样式) 描述如何运行(数据获取、状态更新) 直接使用Redux 否 是 数据来源 props 监听Redux state 数据修改 从props调用回调函数...这些组件只定义外观不关心数据来源和如何改变。传入什么就渲染什么。如果把代码从Redux迁移到别的结构。这些组件可以不做任何改动的直接使用。

    2.1K20

    前端高频react面试题

    ,数据修改更新的角色由Reducers来担任,store只做存储,中间人,当Reducers的更新完成以后会通过store的订阅来通知react component,组件把新的状态重新获取渲染,组件中也能主动发送...state 在什么时候,由于什么原因,如何变化已然不受控制。 当系统变得错综复杂的时候,想重现问题或者添加新功能就会变得举步维艰。...但是对于合成事件来说,有一个事件池专门来管理它们的创建和销毁,当事件需要被使用时,就会从池子中复用对象,事件回调结束后,就会销毁事件对象上的属性,从而便于下次复用事件对象。...这个问题就设计到了数据持久化, 主要的实现方式有以下几种:Redux: 将页面的数据存储在redux中,在重新加载页面时,获取Redux中的数据;data.js: 使用webpack构建的项目,可以建一个文件...在使用 React Router时,如何获取当前页面的路由或浏览器中地址栏中的地址?

    4K20

    2021高频前端面试题汇总之React篇

    2021高频前端面试题汇总之React篇 React视频教程系列 React 实战:CNode视频教程 完整教程目录:点击查看 React经典教程-从入门到精通 完整教程目录:点击查看 最新最全前端毕设项目...React 组件中怎么做事件代理?它的原理是什么?...,数据修改更新的角色由Reducers来担任,store只做存储,中间人,当Reducers的更新完成以后会通过store的订阅来通知react component,组件把新的状态重新获取渲染,组件中也能主动发送...state 在什么时候,由于什么原因,如何变化已然不受控制。 当系统变得错综复杂的时候,想重现问题或者添加新功能就会变得举步维艰。...一些库如 React 视图在视图层禁止异步和直接操作 DOM来解决这个问题。美中不足的是,React 依旧把处理 state 中数据的问题留给了你。Redux就是为了帮你解决这个问题。

    2.5K00

    redux基础概念及执行流程详解

    1.执行createStore 创建一个容器store来用来管理公用的状态信息 创建一个事件池,用来存储一些方法(方法一般都是用来通知某个组件重新渲染的) 当容器中的状态改变,会自动通知事件池中的方法依次执行...2.基于store.getState可以获取容器中存储的状态信息(拿到状态信息就可以做数据绑定等操作了) 3.我们可以基于store.subscribe向事件池中追加方法(也可以移除事件池中的方法)...如何去修改状态信息 公共状态信息都是reducer去改的,reducer记录了所有修改状态的行为方式,我们以后想要知道怎么改的状态,只要看reducer即可。...redux:不局限于任何框架(vue/react/angular/jquery...) react-redux:把redux进一步封装,专门给react框架开发的(操作起来更简洁) vuex:类似于redux...store中没有,我们给一个初始值) //action: 告诉reduce如何去修改状态都在action中(它是一个对象,对象中固定的有type属性:派发任务的行为标识,reducer就是根据不同的行为标识来修改状态信息的

    89510

    Redux入门实战——todo-list2.0实现

    1.前言 在之前的博客中,我写了一篇关于todo-list实现的博客,一步一步详细的记录了如何使用基础的React知识实现一个React单页面应用,通过该篇文章,能够对React入门开发有一个直观的认识和粗浅的理解...如果有数据需要添加,在action中一并传过来。...、样式 描述如何运行(数据获取、状态更新) 直接使用Redux 否 是 数据来源 props.../components/TodoList' //获取符合条件的todo, // todos state中的todo数据 // filter state中的过滤条件 const getVisibleTodos...redux的一些基础概念,基本用法和如何如react进行结合,实现react的功能开发,主要内容包括redux基础,redux于react结合,实例完成步骤,完整代码,项目演示等,比较适合刚接触redux

    1.5K10

    深度理解Redux原理并实现一个redux

    ,好了废话不多说了,我们先来看看Redux在项目中是如何是用的。...各位同学可以看得到我在reducer中做了一次state的深克隆,这是为什么呢?...是因为在每一次的action中我们拿到的是同一个state的内存地址,我们的期望是不管你在switch中如何更改state但是我不希望在这一步就改变了公共状态中的count,只有在我return的时候才会去更改真正的公共状态...而state = initialValue这一步的操作就是第一次派发的时候,reducer接收的state为空,我们把基础值赋给它。了解了这么多,我们还是去看一下他的源码是如何实现的吧。...,官方推荐使用react-redux来进行实际的项目开发,因为他只关注于数据管理。

    52510

    Redux入门实战——todo-list2.0实现

    1.前言 在之前的博客中,我写了一篇关于todo-list实现的博客,一步一步详细的记录了如何使用基础的React知识实现一个React单页面应用,通过该篇文章,能够对React入门开发有一个直观的认识和粗浅的理解...如果有数据需要添加,在action中一并传过来。...原文链接:展示组件和容器组件相分离 译文链接:展示组件和容器组件相分离 3.3.2 展示组件和容器组件比较 展示组件 容器组件 作用 描述如何展示骨架、样式 描述如何运行(数据获取、状态更新)...直接使用Redux 否 是 数据来源 props 监听Redux state 数据修改 从props调用回调函数 向Redux派发action 调用方式 手动 通常由React Redux生成 大部分的组件都应该是展示型的.../components/TodoList' //获取符合条件的todo, // todos state中的todo数据 // filter state中的过滤条件 const getVisibleTodos

    1.3K30

    医疗数字阅片-医学影像-Module: Panel-自定义面板-中二-Redux&react-redux状态管理详解

    ://hardocs.com/d/redux/react-redux/ React:负责组件的UI界面渲染; Redux:数据处理中心; React-Redux:连接组件和数据中心,也就是把React...而 React-redux 就是把 Redux 这种架构模式和 React.js 结合起来的一个库,就是 Redux 架构在 React.js 中的体现。...Action 是把数据从应用(译者注:这里之所以不叫 view 是因为这些数据有可能是服务器响应,用户输入或其它非 view 的数据 )传到 store 的有效载荷。它是 store 数据的唯一来源。...参照 Flux 标准 Action 获取关于如何构造 action 的建议。 这时,我们还需要再添加一个 action index 来表示用户完成任务的动作序列号。...或者 “任务列表里添加了'学习 Redux 文档'”。 你可以在任何地方调用 store.dispatch(action),包括组件中、XHR 回调中、甚至定时器中。

    4.1K10

    2022社招React面试题 附答案

    React 组件中怎么做事件代理?它的原理是什么?...对React的插槽(Portals)的理解,如何使用,有哪些使用场景 React 官方对 Portals 的定义: Portal 提供了一种将子节点渲染到存在于父组件以外的 DOM 节点的优秀的方案 Portals...,数据修改更新的角色由Reducers来担任,store只做存储,中间人,当Reducers的更新完成以后会通过store的订阅来通知react component,组件把新的状态重新获取渲染,组件中也能主动发送...state 在什么时候,由于什么原因,如何变化已然不受控制。 当系统变得错综复杂的时候,想重现问题或者添加新功能就会变得举步维艰。...一些库如 React 视图在视图层禁止异步和直接操作 DOM来解决这个问题。美中不足的是,React 依旧把处理 state 中数据的问题留给了你。Redux就是为了帮你解决这个问题。

    2.4K50

    Redux的设计模式

    我们都知道React中数据流向是单向的,而且总是自上而下传递的,可以通过props将数据从父组件传递给子组件,但是假设我们需要将组件树最底层的Banner节点的数据传递给最顶层的Index,这个时候组件之间该如何通信呢...虽然从原理来看Redux似乎挺简单的但是想要了解他的工作流程就比较麻烦了。 这主要是因为他的数据流动方式不是特别直观,有点类似事件驱动的方式,我们知道事件驱动开发最困难的地方是在调试。...简化后的六层我们只保留Reducer,Store,React组件,Actions这四个部分。为了更加清晰我们这里将Reducer从Store中移了出来,实际上他们是一体的。...所以Store就是Redux中具有推送功能的数据仓库,Reducer是Store处理数据的方法可以帮助Store实现数据的初始化,修改或者删除,Actions就是数据更新的指令,他会告诉Reducer如何去处理数据所以...getState来获取数据,通过subscribe订阅来监听数据的变化,因为Redux是一种发布订阅模式,只有监听才会获取到。

    1.7K20

    深度理解Redux原理并实现一个redux_2023-02-28

    ,好了废话不多说了,我们先来看看Redux在项目中是如何是用的。...各位同学可以看得到我在reducer中做了一次state的深克隆,这是为什么呢?...是因为在每一次的action中我们拿到的是同一个state的内存地址,我们的期望是不管你在switch中如何更改state但是我不希望在这一步就改变了公共状态中的count,只有在我return的时候才会去更改真正的公共状态...而state = initialValue这一步的操作就是第一次派发的时候,reducer接收的state为空,我们把基础值赋给它。了解了这么多,我们还是去看一下他的源码是如何实现的吧。...,官方推荐使用react-redux来进行实际的项目开发,因为他只关注于数据管理。

    61640

    函数式编程在ReduxReact中的应用

    从作用上看,map 帮我们建立了一层抽象屏障,将序列转换的函数实现,与如何提取序列中元素以及组合结果的细节隔离开。...函数式编程在Redux/React中的应用 从reduce到Redux reduce reduce 是对列表的迭代操作的抽象,map 和 filter 都可以基于 reduce 进行实现。...等一下,上述Redux实现貌似缺了些什么…… 是的,在Redux中,状态的改变和获取是通过两个函数来操作的:dispatch、getState,接下来我们将这两个函数添加进去。...纯函数在React中的应用 Redux可以用作React的数据管理(数据源),React接受Redux输出的state,然后将其转换为浏览器中的具体页面展示出来: view = React(state)...然后我们展示了如何从列表处理方法 reduce 推导出可用的事件流处理框架Redux,并将 reduce 的加强版 transduce 与Redux的 middleware 做了类比。

    2.6K90

    字节前端面试被问到的react问题

    面试题详细解答redux 有什么缺点一个组件所需要的数据,必须由父组件传过来,而不能像 flux 中直接从 store 取当一个组件相关数据更新时,即使父组件不需要用到这个组件,父组件还是会重新 render...∶Action∶ 一个JavaScript对象,描述动作相关信息,主要包含type属性和payload属性∶ o type∶ action 类型; o payload∶ 负载数据;Reducer∶ 定义应用状态如何响应不同动作...,异步任务(通常都是业务或获取数据任务)也不例外,而为了不将业务或数据相关的任务混入React组件中,就需要使用其他框架配合管理异步任务流程,如redux-thunk,redux-saga等;Mobx是一个透明函数响应式编程的状态管理库...,且没有任何其他影响的数据对比总结:redux将数据保存在单一的store中,mobx将数据保存在分散的多个store中redux使用plain object保存数据,需要手动处理变化后的操作;mobx...commit阶段是对上一阶段获取到的变化部分应用到真实的DOM树中,是一系列的DOM操作。不仅要维护更复杂的DOM状态,而且中断后再继续,会对用户体验造成影响。

    2.5K20
    领券