Aprender e entender React - o tutorial prático

Gestão do estado no leitor de vídeo com useEffect

Todos os vídeos do tutorial Aprender e entender React - o tutorial prático

Venha e mergulhe no mundo do React! Você aprenderá como reagir a alterações no src-prop do seu player de vídeo e como redefinir efetivamente o estado do player. Este tutorial mostrará como gerenciar corretamente o estado do seu player de vídeo para garantir uma experiência de usuário tranquila.

Principais aprendizados

  • Use useEffect para reagir a alterações em props.
  • Redefina vários estados quando a props src for alterada.
  • Certifique-se de que outros parâmetros, como volume e posição, sejam inicializados corretamente

Guia passo-a-passo

Para implementar as funcionalidades desejadas, começamos com a integração e a configuração do hook useEffect.

Gestão do estado no leitor de vídeo com useEffect

Deve certificar-se de que o seu leitor de vídeo está inicialmente configurado corretamente. Na implementação anterior, verificámos que o estado do leitor não é atualizado corretamente quando o vídeo é alterado.

Gestão do estado no leitor de vídeo com useEffect

O foco principal está no src-prop do elemento de vídeo. Se alterar o vídeo, o estado do leitor, que contém informações sobre o estado da reprodução, tem de ser reposto.

Gestão do estado no leitor de vídeo com useEffect

Abra o componente no qual pretende implementar a lógica e certifique-se de que o gancho useEffect é importado. Aqui, pode deixar temporariamente uma matriz vazia como dependência.

Gestão do estado no leitor de vídeo com useEffect

Agora vai adaptar o useEffect em conformidade. Você especifica src como uma variável dependente para que o React possa reagir às alterações. Isso permitirá que você redefina o estado quando a prop src for alterada.

Para o processo de reinicialização, você definirá vários estados, incluindo isPlaying, duração, volume e posição. Defina isPlaying como false quando for selecionado um novo vídeo para garantir que o leitor funciona corretamente quando é reiniciado.

Além disso, tem de repor a duração do vídeo a zero e configurar o volume para o valor máximo de 100. Tenha em atenção que a propriedade de volume do elemento de vídeo varia entre 0 e 1, por isso defina-a para 1.

Não se esqueça de repor também a posição do vídeo. Isto garante que, quando reproduzir um novo vídeo, o progresso não é retirado do vídeo anterior.

Depois de tudo ter sido reposto, recarregue a sua aplicação para verificar se as alterações tiveram efeito.

Gestão do estado no leitor de vídeo com useEffect

Selecione um vídeo e reproduza-o. Em seguida, teste a alteração do vídeo para se certificar de que todas as reposições funcionam como pretendido.

Gestão do estado no leitor de vídeo com useEffect

Verificará que, após a alteração do vídeo, o estado do leitor é agora corretamente reposto: o volume, a posição de reprodução e o estado de reprodução estão corretos. Isto garante uma utilização fiável.

Se notar que, por vezes, o volume não é reposto a 100%, terá de fazer ajustes aqui. Certifique-se de que também define o volume do elemento de vídeo para 100% depois de ter aumentado o volume, para garantir que o utilizador recebe uma saída de áudio nítida.

Teste as alterações ligando novamente o vídeo e verificando as funções de reprodução.

Gestão do estado no leitor de vídeo com useEffect

Também é importante eliminar quaisquer erros que possam ter ocorrido, como a definição incorrecta do valor src. Por conseguinte, teste a página regularmente para garantir que tudo está configurado como deve estar quando o URL é carregado pela primeira vez.

Gestão do estado no leitor de vídeo com useEffect

Com estes ajustes, garantiu que o seu leitor de vídeo é reiniciado corretamente ao alterar o src. Esse uso do useEffect demonstra a manipulação eficaz de efeitos de componente no React.

Resumo

Em conclusão, você aprendeu como usar o hook useEffect para gerenciar e redefinir o estado do seu player de vídeo quando a propriedade src é alterada. Essa técnica importante ajudará você a criar uma experiência perfeita e fácil de usar.