站長資訊網
        最全最豐富的資訊網站

        什么是react柯里化

        在react中,柯里化是一種關于函數的高階技術,指的是通過函數繼續返回函數的方式,實現多次接收參數最后統一處理的函數編碼形式;柯里化不會調用函數,只是對函數進行轉換,通過柯里化在處理表單時,可以輕松的獲取表單控件數據。

        什么是react柯里化

        本教程操作環境:Windows10系統、react17.0.1版、Dell G3電腦。

        什么是react柯里化

        函數的柯里化:

        通過函數調用繼續返回函數的方式,實現多次接受參數最后統一處理的函數編碼形式.

        擴展:

        高階函數: 若一個函數符合下面兩個規范中的一個,該函數就是高階函數

        1.若a函數,接受的參數是一個函數,那么a就可以稱為高階函數

        2.若a函數,調用的返回值依舊是一個函數,那么a就可以稱之為高階函數

        3.常見的高階函數有:promise,setTimeout,arr.map等

        示例如下;

        什么是react柯里化

        在form表單中,使用受控組件綁定狀態數據,實現點擊顯示表單數據:

        import React, {Component} from 'react'; export default class Form extends Component{   state = {     userName: '',     password: ''   }   submitForm = (event) => {     event.preventDefault() //阻止表單提交     const {userName, password } = this.state;     alert(`${userName}, ${password}`)   }   updateUserName = (event) => {     this.setState({       userName: event.target.value,     })   }   updatePassword = (event) => {     this.setState({       password: event.target.value,     })   }   render() {     return (       <form onSubmit={this.submitForm}>         用戶名:<input type="text" name="userName" onChange={this.updateUserName}/>         密碼: <input type="password" name="password" onChange={this.updatePassword}/>         <button>登錄</button>       </form>     )   } }

        可以看到,這種方法對于表單項多的情況比較繁瑣,可以利用函數柯里化來優化:

        import React, {Component} from 'react'; export default class Form extends Component{   state = {     userName: '',     password: ''   }   submitForm = (event) => {     event.preventDefault() //阻止表單提交     const {userName, password } = this.state;     alert(`${userName}, ${password}`)   }   updateFormData = (key) => {     return (event) => {       this.setState({         [key]: event.target.value,       })     }   }   render() {     return (       <form onSubmit={this.submitForm}>         用戶名:<input type="text" name="userName" onChange={this.updateFormData('userName')}/>         密碼: <input type="password" name="password" onChange={this.updateFormData('password')}/>         <button>登錄</button>       </form>     )   } }

        this.updateFormData()的返回值是一個回調函數,綁定為onChange的事件,參數為event。這樣就可以在初次調用時傳類型,觸發改變事件時傳值了。

        不使用函數柯里化的實現

        直接在onChange事件綁定為回調,可以實現同時傳遞類型和值兩個參數。

        import React, {Component} from 'react'; export default class Form extends Component{   state = {     userName: '',     password: ''   }   submitForm = (event) => {     event.preventDefault() //阻止表單提交     const {userName, password } = this.state;     alert(`${userName}, ${password}`)   }   updateFormData = (key, event) => {     this.setState({       [key]: event.target.value,     })   }   render() {     return (       <form onSubmit={this.submitForm}>         用戶名:<input type="text" name="userName" onChange={(event) => this.updateFormData('userName', event)}/>         密碼: <input type="password" name="password" onChange={(event) => this.updateFormData('password', event)}/>         <button>登錄</button>       </form>     )   } }

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 国产精品国产三级国产专播| 国产午夜精品理论片| 久久这里只精品国产99热| 亚洲国产精品自在拍在线播放| 欧美精品成人3d在线| 91精品国产91久久久久福利| 影院无码人妻精品一区二区| 国产精品单位女同事在线| 国产91久久精品一区二区| 亚洲国产精品无码久久SM| 久久国产综合精品五月天| 色偷偷888欧美精品久久久| 国产精品无码av在线播放| 亚洲AV无码久久精品成人 | 精品深夜AV无码一区二区| 免费精品国产自产拍在线观看| 成人亚洲日韩精品免费视频| 精品综合久久久久久97超人| 久久精品国产亚洲av日韩| 自拍偷自拍亚洲精品情侣| 国产精品免费看久久久香蕉 | 精品视频无码一区二区三区| 无码人妻精品一区二区三区66| 免费精品精品国产欧美在线欧美高清免费一级在线 | 国产精品你懂得| 99热国内精品| 国产成人久久精品一区二区三区| 久久精品天天中文字幕人妻 | 国产亚洲精品高清在线| 丝袜美腿国产精品视频一区| 国产精品大白天新婚身材| 91麻豆精品国产自产在线观看亚洲| 国产成人无码精品一区二区三区 | 99久久99久久精品国产片果冻| 久久精品国产精品青草app| 国产精品久久久福利| 97精品国产一区二区三区| 国产精品亚洲A∨天堂不卡| 国产精品成人观看视频国产奇米| 精品久久久久中文字幕日本| 久久香蕉国产线看观看精品yw|