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

React?Hooks?實(shí)現(xiàn)的中文輸入組件

 更新時(shí)間:2023年05月16日 11:37:15   作者:知名噴子  
這篇文章主要為大家介紹了React?Hooks實(shí)現(xiàn)的中文輸入組件示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

正文

在前端開發(fā)中,通過監(jiān)聽 onInput 事件來觸發(fā)輸入框內(nèi)容的更新,是沒有問題的,但如果輸入的內(nèi)容有中文的時(shí)候,會(huì)出現(xiàn)類似 zhong'wen'nei'rong這樣的備選內(nèi)容。

這種內(nèi)容的影響普遍不會(huì)很大,但是當(dāng)需要對(duì)輸入的內(nèi)容進(jìn)行一些耗時(shí)的操作的時(shí)候,這個(gè)影響就不得不考慮一下了,比如說內(nèi)容需要進(jìn)行復(fù)雜的渲染、通過網(wǎng)絡(luò)實(shí)時(shí)發(fā)送等等場景。

先等待而不觸發(fā)onInput事件

對(duì)這種問題的解決方案,需要借助瀏覽器提供的組合輸入事件 。簡單地說,輸入中日韓文等各種包含“選字”環(huán)節(jié)的文字的時(shí)候,會(huì)額外觸發(fā)兩個(gè)事件compositionStartcompositionEnd,監(jiān)聽并處理這兩個(gè)事件,就可以在用戶還未完成選字的時(shí)候先等待而不觸發(fā)onInput事件:

源自MDN 文檔: compositionstart

如果僅僅需要處理組合輸入的話,使用 compositionEnd 代替 onInput 就可以,但用戶偶爾也需要輸入英文和數(shù)字,這些輸入不會(huì)觸發(fā) compositionEnd。

因此我們需要在 compositionStart 的時(shí)候進(jìn)入等待狀態(tài),等待狀態(tài)中間的所有 onInput 一律不處理。而輸入英文和字母的時(shí)候,onInput 則正常處理。

標(biāo)記等待狀態(tài)的方法

標(biāo)記等待狀態(tài)的方法比較多,例如useRef。

import { useRef, useState } from "react";
export function ChineseInput(params){
    const { onInput = () => {} } = params;
    const lockRef = useRef(false);
    // preview 用于預(yù)覽,不然都不知道自己打的什么內(nèi)容
    const [preview, setPreview] = useState(value);
    // 進(jìn)入組合輸入狀態(tài)
    const handleStart = () => {
      lockRef.current = true
    };
    const handleInput = event => {
      // 不管狀態(tài)如何,總是需要預(yù)覽的
      setPreview(event.target.value);
      // 處于組合輸入狀態(tài),不予處理
      if(lockRef.current) return;
      // 非組合輸入狀態(tài),觸發(fā) onInput
      onInput(event);
    };
    // 選字結(jié)束,觸發(fā) onInput
    const handleEnd = event => {
      setPreview(event.target.value);
      lockRef.current = false;
      onInput(event);
    };
    return (
      <input
        {...params}
        onCompositionEnd={handleEnd}
        onCompositionStart={handleStart}
        onInput={handleInput}
      />
    )
  }

 當(dāng)然這里可以改成一個(gè)高階函數(shù)或者自定義鉤子,這樣的話就不用單獨(dú)給 textArea 也寫一個(gè)組件了,不過常見的輸入標(biāo)簽也就這倆,沒有必要復(fù)用。

這兩個(gè)事件的兼容性還不錯(cuò):

 還在用比這更老的瀏覽器的電腦基本可以忽略掉,硬要兼容的話,怕是只有用適當(dāng)魔改的防抖或者節(jié)流函數(shù)來代替了。

以上就是React Hooks 實(shí)現(xiàn)的中文輸入組件的詳細(xì)內(nèi)容,更多關(guān)于React Hooks中文輸入組件的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • React?懸浮框內(nèi)容懶加載實(shí)例詳解

    React?懸浮框內(nèi)容懶加載實(shí)例詳解

    這篇文章主要為大家介紹了React?懸浮框內(nèi)容懶加載實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • React?JSX深入淺出理解

    React?JSX深入淺出理解

    React使用JSX來替代常規(guī)的JavaScript。JSX是一個(gè)看起來很像 XML的JavaScript語法擴(kuò)展。我們不需要一定使用 JSX,但它有以下優(yōu)點(diǎn):JSX執(zhí)行更快,因?yàn)樗诰幾g為JavaScript代碼后進(jìn)行了優(yōu)化。它是類型安全的,在編譯過程中就能發(fā)現(xiàn)錯(cuò)誤。使用JSX編寫模板更加簡單快速
    2022-12-12
  • react組件memo useMemo useCallback使用區(qū)別示例

    react組件memo useMemo useCallback使用區(qū)別示例

    這篇文章主要為大家介紹了react組件memo useMemo useCallback使用區(qū)別的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • 簡單介紹react redux的中間件的使用

    簡單介紹react redux的中間件的使用

    這篇文章主要介紹了簡單介紹redux的中間件的使用,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-04-04
  • React在定時(shí)器中無法獲取狀態(tài)最新值的問題

    React在定時(shí)器中無法獲取狀態(tài)最新值的問題

    這篇文章主要介紹了React在定時(shí)器中無法獲取狀態(tài)最新值的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • ReactNative踩坑之配置調(diào)試端口的解決方法

    ReactNative踩坑之配置調(diào)試端口的解決方法

    本篇文章主要介紹了ReactNative踩坑之配置調(diào)試端口的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • react native與webview通信的示例代碼

    react native與webview通信的示例代碼

    本篇文章主要介紹了react native與webview通信的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-09-09
  • Suspense對(duì)React的意義及作用解析

    Suspense對(duì)React的意義及作用解析

    這篇文章主要為大家介紹了Suspense對(duì)React的意義及作用解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • Express+React+Antd實(shí)現(xiàn)上傳功能(前端和后端)

    Express+React+Antd實(shí)現(xiàn)上傳功能(前端和后端)

    這篇文章主要介紹了Express+React+Antd實(shí)現(xiàn)上傳功能(前端和后端),本文通過示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2024-04-04
  • webpack入門+react環(huán)境配置

    webpack入門+react環(huán)境配置

    webpack是一個(gè)前端資源模塊化管理和打包工具,說白了就是方便我們管理自己的常用的一些代碼,比如你開發(fā)中用到sass以及jade同時(shí)用到es6,開發(fā)時(shí)你不可能改動(dòng)某個(gè)地方就挨個(gè)命令去轉(zhuǎn)換再到瀏覽器去看效果,那樣效率是非常低的。所以webpack幫我們省去了那些多余的步驟。
    2017-02-02

最新評(píng)論