小編給大家分享一下React/Redux應(yīng)用如何使用Async/Await,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比金昌網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式金昌網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋金昌地區(qū)。費(fèi)用合理售后完善,10余年實(shí)體公司更值得信賴。
Async/Await是尚未正式公布的ES7標(biāo)準(zhǔn)新特性。簡而言之,就是讓你以同步方法的思維編寫異步代碼。對(duì)于前端,異步任務(wù)代碼的編寫經(jīng)歷了 callback 到現(xiàn)在流行的 Promise ,最終會(huì)進(jìn)化為 Async/Await 。雖然這個(gè)特性尚未正式發(fā)布,但是利用babel polyfill我們已經(jīng)可以在應(yīng)用中使用它了。
現(xiàn)在假設(shè)一個(gè)簡單的React/Redux應(yīng)用,我將引入 Async/Await 到其代碼。
Actions
此例子中有一個(gè)創(chuàng)建新文章的 Action ,傳統(tǒng)方法是利用 Promise 結(jié)合 Redux-thunk 中間件實(shí)現(xiàn)。
import axios from 'axios' export default function createPost (params) { const success = (result) => { dispatch({ type: 'CREATE_POST_SUCCESS', payload: result }) return result } const fail = (err) => { dispatch({ type: 'CREATE_POST_FAIL', err }) return err } return dispatch => { return axios.post('http://xxxxx', params) .then(success) .catch(fail) } }
現(xiàn)在將它改寫為 async/await 的實(shí)現(xiàn):
import axios from 'axios' export default function createPost (params) { const success = (result) => { dispatch({ type: 'CREATE_POST_SUCCESS', payload: result }) return result } const fail = (err) => { dispatch({ type: 'CREATE_POST_FAIL', err }) return err } return async dispatch => { try { const result = await axios.post('http://xxxxx', params) return success(result) } catch (err) { return fail(err) } } }
async和await是成對(duì)使用的,特點(diǎn)是使代碼看起來和同步代碼類似。
Components
同樣,在React組件中,也比較一下 Promise 和 Async/Await 的方法異同。
傳統(tǒng)地使用 Promise :
import React, { Component } from 'react' import { connect } from 'react-redux' import { createPost } from '../actions/post' class PostEditForm extends Component { constructor(props) { super(props) } contributePost = e => { e.preventDefault() // .... get form values as params this.props.createPost(params) .then(response => { // show success message }) .catch(err => { // show error tips }) } render () { return ( <form onSubmit={this.contributePost}> <input name="title"/> <textarea name="content"/> <button>Create</button> </form> ) } } export default connect(null, dispatch => { return { createPost: params => dispatch(createPost(params)) } })(PostEditForm)
如果使用 Async/Await
import React, { Component } from 'react' import { connect } from 'react-redux' import { createPost } from '../actions/post' class PostEditForm extends Component { constructor(props) { super(props) } async contributePost = e => { e.preventDefault() // .... get form values as params try { const result = await this.props.createPost(params) // show success message } catch (err) { // show error tips } } render () { return ( <form onSubmit={this.contributePost}> <input name="title"/> <textarea name="content"/> <button>Create</button> </form> ) } } export default connect(null, dispatch => { return { createPost: params => dispatch(createPost(params)) } })(PostEditForm)
可以見得,兩種模式, Async\Await 的更加直觀和簡潔,是未來的趨勢(shì)。但是目前,還需要利用babel的 transform-async-to-module-method 插件來轉(zhuǎn)換其成為瀏覽器支持的語法,雖然沒有性能的提升,但對(duì)于代碼編寫體驗(yàn)要更好。
以上是“React/Redux應(yīng)用如何使用Async/Await”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
分享題目:React/Redux應(yīng)用如何使用Async/Await
鏈接分享:http://muchs.cn/article22/gddsjc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供動(dòng)態(tài)網(wǎng)站、網(wǎng)站設(shè)計(jì)、全網(wǎng)營銷推廣、網(wǎng)站排名、微信公眾號(hào)、做網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)