Enquanto enlace de `esse` para o evento onClick em Reagir componente está dando `Parâmetro 'este' tem implicitamente um "qualquer" tipo " de erro

0

Pergunta

P. S. eu tentei a outra resposta do StackOverflow, mas, de alguma forma, que não funcionou.

Eu estou ligação this para a função de onClick do manipulador como dado abaixo

  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 })}
  />

Mas ele me dá Parameter 'this' implicitly has an 'any' type erro`.

Eu tentei a atribuição de vários tipos de saber. qualquer, vazio,typeof para this como

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

Mas ele dá um tipo de erro necessário. Por favor, me ajudar com o problema.

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

Melhor resposta

1

A seguinte alteração é que funcionou para mim. Em vez de vincular eu só passou evento normal.

Ao chamar manipulador onClick função usada React.MouseEvent<HTMLElement> como tipo de evento

E em função da definição de "_e' para suprimir o param defined but not usederro. Adicioná-lo aqui, para que ela possa ajudar alguém no futuro.

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

Isto pode ser devido ao contexto. em render antes de retornar basta fazer o seguinte; deixe que = isso; e chamar a função usando que, em vez desta. Ele trabalhou para mim.

2021-11-25 12:07:12

Em outros idiomas

Esta página está em outros idiomas

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