首頁  >  文章  >  web前端  >  什麼是react柯里化

什麼是react柯里化

WBOY
WBOY原創
2022-06-27 17:42:091433瀏覽

在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 (
      
用户名: 密码:
) } }

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

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 (
      
用户名: 密码:
) } }

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 (
      
用户名: this.updateFormData('userName', event)}/> 密码: this.updateFormData('password', event)}/>
) } }

【相關推薦:javascript影片教學web前端

以上是什麼是react柯里化的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn