首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

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.3K20

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.6K10
  • 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.6K30

    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.2K20

    React中的Redux

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

    4K20

    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.5K30

    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迁移到别的结构。这些组件可以不做任何改动的直接使用。

    1.8K20

    前端高频react面试题

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

    3.4K20

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

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

    2K00

    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就是根据不同的行为标识来修改状态信息的

    83110

    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.4K10

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

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

    41810

    医疗数字阅片-医学影像-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 回调中、甚至定时器中。

    3.7K10

    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.2K30

    2022社招React面试题 附答案

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

    2K50

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

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

    51540

    Redux的设计模式

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

    1.5K20

    函数式编程在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.2K90

    字节前端面试被问到的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.1K20
    领券