一、React组件访问服务器
10年积累的成都网站设计、成都做网站、外贸网站建设经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站设计后付款的网站建设流程,更有临江免费网站建设让你可以放心的选择与我们合作。代理功能访问API
以显示天气预报为示例:
分两个步骤完成:
(1)在装载过程中,因为weather组件并没有获得服务器结果,就不显示结果。或者显示一个’正在装载‘之类的提示信息,但weather组件这时候要发出对服务器的请求。
(2)获取到天气数据之后,显示出来
在装载过程中,通常我们在组件的componentDidMount函数中做请求服务器的事情。
二、Redux访问服务器
Redux-thunk中间件
使用Redux访问服务器,同样要解决的是异步问题。
Redux的单向数据流是同步操作,驱动Redux流程的是action对象,每一个action对象被派发到Store上之后,同步的被分配给所有的reducer函数,每个reducer都是纯函数,纯函数不产生任何副作用,自然是完成数据操作之后立刻同步返回,reducer返回的结果又被同步的拿去更新Store上的状态数据,更新状态数据的操作会立即被同步给监听Store状态改变的函数,从而引发作为视图的React组件更新过程。
在这个过程中,Redux-chunk可以作为Redux中异步操作的方法之一。
按照Redux-chunk的想法,在Redux的单向数据流中,在action对象被reducer函数处理之前,是插入异步功能的时机。
在Redux架构下,一个action对象在通过store.dispatch派发,在调用reducer函数之前,会先经过一个中间件环节,这就是产生异步操作的时机,实际上Redux-chunk提供的就是一个Redux中间件,我们需要在创建store时用上这个中间件。
异步action对象
当我们想要让Redux帮忙处理一个异步操作的时候,代码一样也要派发一个action对象,毕竟Redux单向数据流就是由action对象驱动的,但是这个引发异步操作的action对象比较特殊,我们叫他们’异步action对象‘。
有了redux-chunk中间件之后,这些action对象根本没有机会触及到reducer函数,在中间件一层就被redux-chunk截获。
redux-chunk的工作是检查action对象是不是函数,如果不是函数就放行,完成普通action对象的生命周期,而如果发现action对象是函数,那就执行这个函数,并把Store的dispatch函数和getState函数作为参数传递到函数中去,处理过程到此为止,不会让这个异步action对象继续往前派发到reducer函数。
异步操作的模式
一个访问服务器的action,至少要涉及3个action类型:
三、如何挑选异步操作方式
在Redux的单向数据流中,什么时机插入异步操作?
Redux的数据流转完全靠action来驱动,对于redux-chunk,切入异步操作的时机是在中间件中,但这并不是唯一的位置。
通过定制化Store Enhancer,可以在action派发路径上任何一个位置插入异步操作,甚至作为纯函数的reducer都可以帮助实现异步操作。异步操作本身就是一种副作用,reducer的执行过程当然不应该产生异步操作,但是reducer函数的返回值却可以包含对异步操作的’指示‘,也就是说,reducer返回的结果可以用纯数据的方式表示需要发起一个对服务器资源的访问,由reducer调用者去真正执行这个访问服务器资源的操作,这样不违背reducer是一个纯函数的原则。
对应库的大小如何?
几KB-几十KB
学习曲线是不是太陡?
如果一个应用只有一个简单的API请求,使用redux-thunk能解决的话就使用redux-thunk。
四、利用Promise实现异步操作
对于Promise在Redux库中如何实现,相关的库也很多,但是都很简单,用一个Redux中间件就可以实现:
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
新闻名称:React总结篇之七_Redux和服务器通信-创新互联
当前路径:/article8/ecpop.html
成都网站建设公司_创新互联,为您提供网站排名、外贸网站建设、网站改版、网站建设、搜索引擎优化、外贸建站
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联