• 技术文章 >web前端 >js教程

    redux和react有啥区别

    藏色散人藏色散人2021-01-21 15:10:07原创1171

    redux和react的区别有:1、redux是一个JavaScript状态容器,而react是Facebook推出的一个用来构建用户界面的JavaScript库;2、redux主要提供状态管理,而react主要用于构建UI等等。

    本教程操作环境:windows7系统、React17版,DELL G3电脑,该方法适用于所有品牌电脑。

    推荐:《javascript基础教程

    区别

    redux

    redux是一个JavaScript状态容器,主要提供状态管理。可以运行于服务端,客户端,原生应用。除了支持React外还支持其他的UI框架,体积小,只有2kb。当要与React一起使用的时候,可以使用react-redux插件来进一步提升我们的开发体验。

    可以通过调用相应的API或者是以相应的机制改变这个容器中的数据就可以了,其他组件可以通过主动重新从容器中获取新数据来重新进行渲染。

    此外这个容器还需支持发布订阅机制,即当某个数据改变了,关心这个数据的组件就产即会得到通知。

    react

    react是 Facebook 推出的一个用来构建用户界面的 JavaScript 库。 React主要用于构建UI,很多人认为 React 是 MVC 中的 V(视图)。React 拥有较高的性能,代码逻辑非常简单,越来越多的人已开始关注和使用它。

    React 是一个为数据提供渲染为 HTML 视图的开源 JavaScript 库。React 视图通常采用包含以自定义 HTML 标记规定的其他组件的组件渲染。React 为程序员提供了一种子组件不能直接影响外层组件的模型,数据改变时对 HTML 文档的有效更新,和现代单页应用中组件之间干净的分离。

    学会用自己的思想来理解React和Redux;不能光听别人描述名词,理解起来是很困难的。

    从需求出发,看看使用React需要什么:

    1、React有props和state: props意味着父级分发下来的属性,state意味着组件内部可以自行管理的状态,并且整个React没有数据向上回溯的能力,也就是说数据只能单向向下分发,或者自行内部消化。

    理解这个是理解React和Redux的前提。

    2、一般构建的React组件内部可能是一个完整的应用,它自己工作良好,你可以通过属性作为API控制它。但是更多的时候发现React根本无法让两个组件互相交流,使用对方的数据。

    然后这时候不通过DOM沟通(也就是React体制内)解决的唯一办法就是提升state,将state放到共有的父组件中来管理,再作为props分发回子组件。

    3、子组件改变父组件state的办法只能是通过onClick触发父组件声明好的回调,也就是父组件提前声明好函数或方法作为契约描述自己的state将如何变化,再将它同样作为属性交给子组件使用。

    这样就出现了一个模式:数据总是单向从顶层向下分发的,但是只有子组件回调在概念上可以回到state顶层影响数据。这样state一定程度上是响应式的。

    4、为了面临所有可能的扩展问题,最容易想到的办法就是把所有state集中放到所有组件顶层,然后分发给所有组件。

    5. 为了有更好的state管理,就需要一个库来作为更专业的顶层state分发给所有React应用,这就是Redux。让我们回来看看重现`上面结构的需求:

    需要回调通知state (等同于回调参数) -> action

    需要根据回调处理 (等同于父级方法) -> reducer

    需要state (等同于总状态) -> store

    对Redux来说只有这三个要素:

    action是纯声明式的数据结构,只提供事件的所有要素,不提供逻辑。

    reducer是一个匹配函数,action的发送是全局的:所有的reducer都可以捕捉到并匹配与自己相关与否,相关就拿走action中的要素进行逻辑处理,修改store中的状态,不相关就不对state做处理原样返回。

    store负责存储状态并可以被react api回调,发布action.

    当然一般不会直接把两个库拿来用,还有一个binding叫react-redux, 提供一个Provider和connect。很多人其实看懂了redux卡在这里。

    Provider是一个普通组件,可以作为顶层app的分发点,它只需要store属性就可以了。它会将state分发给所有被connect的组件,不管它在哪里,被嵌套多少层。

    connect是真正的重点,它是一个科里化函数,意思是先接受两个参数(数据绑定mapStateToProps和事件绑定mapDispatchToProps),再接受一个参数(将要绑定的组件本身):

    mapStateToProps:构建好Redux系统的时候,它会被自动初始化,但是你的React组件并不知道它的存在,因此你需要分拣出你需要的Redux状态,所以你需要绑定一个函数,它的参数是state,简单返回你关心的几个值。

    mapDispatchToProps:声明好的action作为回调,也可以被注入到组件里,就是通过这个函数,它的参数是dispatch,通过redux的辅助方法bindActionCreator绑定所有action以及参数的dispatch,就可以作为属性在组件里面作为函数简单使用了,不需要手动dispatch。这个mapDispatchToProps是可选的,如果不传这个参数redux会简单把dispatch作为属性注入给组件,可以手动当做store.dispatch使用。

    这也是为什么要科里化的原因。

    做好以上流程Redux和React就可以工作了。

    简单地说就是:

    1.顶层分发状态,让React组件被动地渲染。

    2.监听事件,事件有权利回到所有状态顶层影响状态。

    总结:

    react需要一个管理状态的管理者,redux就充当这个角色进行顶层分发状态,改变react组件的渲染。

    以上就是redux和react有啥区别的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:redux react
    上一篇:webstrom 怎么创建react项目 下一篇:jQuery发请求传输中文参数乱码怎么办
    20期PHP线上班

    相关文章推荐

    精选22门好课,价值3725元,开通VIP免费学习!• ajax与jquery的区别是什么• CSS圣杯布局和双飞翼布局的区别是什么?• 网闸与防火墙的区别是什么• React中函数组件与类组件的区别是什么?
    1/1

    PHP中文网