Podczas wiązania `to` do zdarzenia onClick komponentu React opcja to" niejawnie zawiera błąd dowolnego typu

0

Pytanie

P. S. próbowałem inną odpowiedź z StackOverflow, ale jakoś to nie zadziałało.

Kojarzę this do obsługi funkcji onClick, jak określono poniżej

  const handleUpdatePermissionClick = async (user: UserPermission) => {
    try {
      await updateUserPermission(user)
      setShowError(false)
    } catch (e) {
      setShowError(true)
    }
  }

  <MenuItem
    name={ele.name}
    Key={ele.name}
    onClick={handleUpdatePermissionClick.bind(this, { permission: ele, userId })}
  />

Ale to daje mi Parameter 'this' implicitly has an 'any' type błąd`.

Próbowałem przypisać kilka rodzajów, a mianowicie. każdy, pusty,typ this jak

onClick={handleUpdatePermissionClick.bind(this:any, { permission: ele, userId })}

Ale to daje błąd typu "Nie chcesz". Proszę, pomóżcie mi rozwiązać ten problem.

reactjs typescript typescript-typings
2021-11-23 17:36:28
2

Najlepsza odpowiedź

1

Kolejna zmiana to to, że to co działa dla mnie. Zamiast wiązania po prostu przeszedł zwykłe zdarzenie.

Po wywołaniu funkcji obsługi onClick używany React.MouseEvent<HTMLElement> jak typ zdarzenia

I w definicji funkcji służy "_e" dla redukcji param defined but not usedbłąd. Dodaję go tutaj, aby mógł komuś pomóc w przyszłości.

const handleUpdatePermissionClick = async (_e:React.MouseEvent<HTMLElement>,user: UserPermission) => {
   try {
      await updateUserPermission(user)
      setShowError(false)
   } catch (e) {
      setShowError(true)
   }
}

 <MenuItem
   name={ele.name}
   key={ele.name}
   onClick={(e: React.MouseEvent<HTMLElement>) => {
     handleUpdatePermissionClick(e, { permission: ele, userId })
   }}
 />
2021-11-23 17:48:19
0

To może być związane z kontekstem. w trybie renderowania przed zwrotem po prostu wykonaj następujące kroki; niech to = to; i wywołaj funkcję, za pomocą to zamiast tego. To zadziałało na mnie.

2021-11-25 12:07:12

W innych językach

Ta strona jest w innych językach

Русский
..................................................................................................................
Italiano
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................