文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

React路由中的redux和redux知识点拓展

2024-04-02 19:55

关注

路由中使用redux

在路由中使用redux只需要两步:

注意:路由规则渲染组件的时候,路由规则组件只负责向组件传递路由相关的数据,其他的数据(如store数据)是不会传递的

所以Route渲染的组件,想接收store中的数据,我们只能采用第二种方式,渲染处理后的组件。

路由reducer

路由也提供了reducer方法,我们需要引入react-router-redux

提供了routerReducer,表示路由的reducer

我们也想添加到应用中,我们就要使用combineReducers方法添加多个reducer

参数是对象:

key表示state名称(命名空间)

value表示reducer

相当于vuex中的module切割模块

此时合并后,在组件中,访问state数据,要携带命名空间

// 拓展组件
let DealApp = dealFn(App);
let DealHome = dealFn(Home);
let DealList = dealFn(List);
let DealDetail = dealFn(Detail);
// 第二步 确定渲染方式
let routes = (
<HashRouter>
{}
{}
<Route path="/" component={DealApp}></Route>
</HashRouter>
)
// 2 在provider中,渲染路由规则
render(<Provider store={store}>{routes}</Provider>, app)

Redux拓展

state拓展

我们目前操作的state都是一个值类型的数据

因此我们可以直接操作这个state数据

如果state是一个引用类型的数据,我们就不能在state上直接操作了

我们要先定义新对象,在新对象上操作数据,最终与原来的state合并成新对象,并返回这个新对象作为新的state数据

我们可以通过ES6提供的Object.assign方法来合并对象,

由于后面的数据会覆盖前面的数据,因此我们将新对象放在state对象之后。

action拓展

action是一个通信的对象,里面携带消息数据

静态action

我们目前定义的action对象都是一个静态的action对象,

也就是说action中的数据是固定的

适用性会收到限制。为了提高适用性,我们可以定义动态action

动态action

动态action是一个函数,可以接收参数,我们根据参数的不同,返回不同的action,这样就增强了action对象的适用性了

异步action

到目前为止,我们所发送的action都是同步的,因为在action中没有异步的操作

异步action适用场景:

react是一个视图层的框架,但是我们有时候将请求放在组件中,就会让组件做了太多数据业务逻辑方面的事情了,有时候我们想将这部分请求放在action实现,此时这个action就是一个异步的action

异步action与同步action相比:

异步action中间件

redux-thunk是异步action中间件

我们可以通过applyMiddleware方法,将其安装在redux中,

该方法参数就是中间件,返回一个新的方法,用来拓展createState方法,会得到一个新的创建store方法,此时我们用这个新的方法创建store,新的store就具有了异步aciton的功能。

到此这篇关于React路由中的redux和redux知识点拓展的文章就介绍到这了,更多相关React redux和redux内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-前端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯