欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

react中事件處理與柯里化的實現(xiàn)

 更新時間:2022年05月24日 09:20:39   作者:Junerver  
本文主要介紹了react中事件處理與柯里化的實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

1. 事件處理

React 中元素也可接受、處理事件,但是在語法上有一點不同。

在React 中所有事件的命名采用的是小駝峰,而非原生 DOM 的純小寫,所有事件需要我們傳入一個函數,而非字符串。

例如:

const Button = () => {
    const handleClick = () => {
        console.log('click')
    }
    return <button onClick={handleClick}>click button</button>
}

當事件的回調函數比較簡單時,我們也可以簡寫箭頭匿名函數,例如:

const Button = () => {
    return (
        <button
            onClick={() => console.log('click')}
        >
            click button
        </button>)
}

阻止默認行為

在React 中不能通過返回 false 來阻止默認行為,例如表單提交、a標簽跳轉。我們必須要通過顯式調用 preventDefault 函數,來阻止這些默認行為。

const Link = () => {
    return <a
         rel="external nofollow"  rel="external nofollow" 
        onClick={(e) => e.preventDefault()}
    >
        link
    </a>
}

合成事件

在 React 中幾乎所有的事件處理函數,都是一個 (event)=>void 函數,如果我們使用 typescript,可以清晰的看到每個事件對應的函數類型,React 自身也聲明了很多的事件與事件處理函數類型,例如鼠標事件:MouseEvent<T = Element>MouseEventHandler<T = Element>,我們在使用時可以根據自己的喜歡,是定義函數類型還是定義參數類型,就像這樣:

const Link = () => {
    const handleClick = (e: MouseEvent) => {
        e.preventDefault()
        console.log('click')
    }
    const handleMouseEnter:MouseEventHandler = (e) => {
        console.log('mouse enter')
    }
    return <a
         rel="external nofollow"  rel="external nofollow" 
        onMouseEnter={handleMouseEnter}
        onClick={handleClick}
    >
        link
    </a>
}

在 React 中,所有事件都是 React 根據 W3C 規(guī)范定義的合成事件,所以我們完全不用擔心兼容性問題,React 事件與原生事件不完全相同。

點擊此處查看合成事件文檔

2. 柯里化

柯里化這個名稱對于 Android 開發(fā)可能有點陌生,因為我們一般使用 Java 開發(fā),因為早期的 Java 不支持函數式編程(FP),而柯里化是一個函數式編程思想。

簡而言之是將一個多參函數變成單參數函數,舉個栗子:

//柯里化后的單參數函數
function sumCurrying(a) {
  return (b) => {
    return (c) => {
      return a + b + c;
    };
  };
}
//普通的多參數函數
function sumNormal(a, b, c) {
  return a + b + c
}
console.log(sumCurrying(1)(2)(3));
console.log(sumNormal(1, 2, 3));

柯里化的本質,就是高階函數的一個特性:函數的返回值可以是一個函數。

上面的例子,似乎有點脫褲子放屁,看似毫無意義。但實際工程中,柯里化是一個非常實用的小 trick。最常用在事件處理需要傳入值的場景。

我們在上面說過了,React 中的事件回調函數是有固定的函數類型的,幾乎都是 (event)=>void 函數。我們需要傳入一些參數給這個事件處理函數呢?

const List = () => {
    const list = [
        { id: 1, name: 'tom' },
        { id: 2, name: 'jerry' },
        { id: 3, name: 'jack' },
        { id: 4, name: 'lily' },
    ]
    const handleClick = (id: number) => {
        console.log(id)
    }
    return <ul>
        {list.map(item => <li
                onClick={() => handleClick(item.id)}
                key={item.id}
            >
                {item.name}
            </li>
        )}
    </ul>
}

這看起來似乎很不優(yōu)雅,我們已經聲明了 handle 函數,卻又不得不在事件處理函數中寫行內的箭頭函數,如何才能更加優(yōu)雅的處理呢?

其實很簡單,我們只需要在原本的 handle 函數中,插入一個箭頭即可,就像這樣:

//before
const handleClick = (id: number) => {
  console.log(id)
}
//after
const handleClick = (id: number) => (e:MouseEvent) => {
  console.log(id)
}

然后我們的 onClick 事件回調函數就可以改成 onClick={handleClick(item.id)} ,這樣看起來是不是就更加優(yōu)雅了呢?

其實這種設計思想可以說是一說就透,只不過我現(xiàn)在告訴你,這種思想就叫做:柯里化

柯里化的目的

你可能會問我柯里化看起來只是讓我們的代碼優(yōu)雅了一點,在目前看來似乎沒有什么本質上的變化。

但其實柯里化幫助我們實現(xiàn)了函數的一變多,我們用一個日志輸出的函數作為例子:

//原始函數
const log = (date, importance, message) => {
  alert(`[${date.getHours()}:${date.getMinutes()}] [${importance}] ${message}`);
}
//柯里化
const logCurry = (date) => (importance) => (message) => { 
  alert(`[${date.getHours()}:${date.getMinutes()}] [${importance}] ${message}`);
}

柯里化后,函數變成這樣調用:logCurry(new Date())("DEBUG")("some debug");

現(xiàn)在我們相當于擁有這些函數:

// logNow 會是帶有固定第一個參數的日志的函數
let logNow = logCurry(new Date());

// 使用它
logNow("INFO", "message"); // [HH:mm] INFO message

// debugNow 會是帶有固定第一個參數與第二個參數的函數
let debugNow = logNow("DEBUG");

debugNow("message"); // [HH:mm] DEBUG message

看起來只是增加了幾個箭頭,實際上我們函數的靈活性大為增加。通過固定不同的參數,我們從一個函數聲明獲得了多個函數。

一個簡單的例子

const Form = () => {
   const [form, setForm] = React.useState({});
   const update = (name) => (event) => {
     setForm({
       ...form,
       [name]: event.target.value,
     });
   }
   const handleSubmit = (event) => {
     event.preventDefault();
     alert(`${JSON.stringify(form)}`);
   }
   return (
     <div>
       <h1>柯里化表單</h1>
       <FormItem label="用戶名" name='username' update={update} />
       <FormItem label="昵稱" name='nickname' update={update} />
       <FormItem label="郵箱" name='email' update={update} />
       <button onClick={handleSubmit}>提交</button>
     </div>
   )
 }

 const FormItem = ({ label, name, update }) => {
   return (
     <div style={{ 'display': 'flex' }}>
       <label>{label}</label>
       <input onChange={update(name)} type="text" placeholder={`請輸入${label}`} />
     </div>
   );
 };

到此這篇關于react中事件處理與柯里化的實現(xiàn)的文章就介紹到這了,更多相關react 事件處理與柯里化內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • React?split實現(xiàn)分割字符串的使用示例

    React?split實現(xiàn)分割字符串的使用示例

    當我們需要將一個字符串按照指定的分隔符進行分割成數組時,我們可以在組件的生命周期方法中使用split方法來實現(xiàn)這個功能,本文就來介紹一下,感興趣的可以了解下
    2023-10-10
  • 淺談React Router關于history的那些事

    淺談React Router關于history的那些事

    這篇文章主要介紹了淺談React Router關于history的那些事,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04
  • 用React實現(xiàn)一個完整的TodoList的示例代碼

    用React實現(xiàn)一個完整的TodoList的示例代碼

    本篇文章主要介紹了用React實現(xiàn)一個完整的TodoList的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • 詳解react-router-dom v6版本基本使用介紹

    詳解react-router-dom v6版本基本使用介紹

    本文主要介紹了react-router-dom v6版本基本使用介紹,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • react性能優(yōu)化達到最大化的方法 immutable.js使用的必要性

    react性能優(yōu)化達到最大化的方法 immutable.js使用的必要性

    這篇文章主要為大家詳細介紹了react性能優(yōu)化達到最大化的方法,一步一步優(yōu)化react性能的過程,告訴大家使用immutable.js的必要性,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • React生命周期方法之componentDidMount的使用

    React生命周期方法之componentDidMount的使用

    這篇文章主要介紹了React生命周期方法之componentDidMount的使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • react字符串匹配關鍵字高亮問題

    react字符串匹配關鍵字高亮問題

    這篇文章主要介紹了react字符串匹配關鍵字高亮問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • React中useLayoutEffect鉤子使用場景詳解

    React中useLayoutEffect鉤子使用場景詳解

    這篇文章主要為大家介紹了React中useLayoutEffect鉤子使用場景詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • 使用react的7個避坑案例小結

    使用react的7個避坑案例小結

    React是個很受歡迎的前端框架。今天我們探索下React開發(fā)者應該注意的七點,感興趣的小伙伴們可以參考一下
    2021-05-05
  • React解析html 標簽的方法

    React解析html 標簽的方法

    在React中,解析HTML標簽通常是使用JSX(JavaScript XML)語法的一部分,這篇文章主要介紹了React 用來解析html 標簽的方法,本文通過示例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2023-08-08

最新評論