質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.30%
React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

Q&A

解決済

1回答

2645閲覧

reactでuseNavigateを使ったメソッド名でエラーが出る

Kome314

総合スコア20

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

0グッド

0クリップ

投稿2022/01/22 11:42

reactでログイン画面の作成をしています。
react-router-domはv6です。

useNavigateを読み込んで、login後home('/')に遷移させたいのですが、下記エラーが出ます。

React Hook "useNavigate" is called in function "signup" that is neither a React function component nor a custom React Hook function. React component names must start with an uppercase letter. React Hook names must start with the word "use"

AuthProvider.js

1import React, { useEffect, useState } from "react"; 2import {auth} from "../firebase/firebase"; 3import { useNavigate } from 'react-router-dom'; 4 5const AuthContext = React.createContext() 6const AuthProvider = ( { children }) => { 7 const [currentUser, setCurrentUser] =useState(null); 8 9 const signup = async ( email, password ) =>{ 10 try{ 11 const navigate = useNavigate(); 12 await auth.createUserWithEmailAndPassword( email, password ); 13 auth.onAuthStateChanged( user => setCurrentUser(user)); 14 navigate('/'); 15 } 16 catch( error ) { 17 alert( error ); 18 } 19 } 20 21const login = async ( email, password ) =>{ 22 try{ 23 const navigate = useNavigate(); 24 await auth.signInWithEmailAndPassword( email ,password ); 25 auth.onAuthStateChanged( user => setCurrentUser( user )); 26 navigate('/'); 27 } catch( error ){ 28 console.log( error ); 29 } 30} 31useEffect(() =>{ 32 auth.onAuthStateChanged( setCurrentUser ); 33}, []); 34 35return( 36 <AuthContext.Provider value={{ signup, login, currentUser}}> 37 {children} 38 </AuthContext.Provider>) 39} 40export {AuthContext, AuthProvider}

フックを使用したメソッド名はuseから始めているし、頭文字を大文字に変更してもエラーは変わらず、もし解決方法をご存知の方がいらっしゃいましたら、回答いただけますと大変助かります。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hoshi-takanori

2022/01/22 15:21

フック関数は関数コンポーネントから呼ぶ必要がありますが、signup や login はコンポーネントとは独立して呼ばれる関数だからかと。const navigate = useNavigate(); を AuthProvider から直接呼べば良いのでは。
Kome314

2022/01/25 07:37

エラーを勘違いしており、おっしゃっていただいた通りフック関数の書く場所が誤っていました。修正したところ、問題解決しました。 ありがとうございます!
guest

回答1

0

自己解決

useNavigateをuseStateの下に記述することで解決しました。コメントいただいた方、ありがとうございました。

投稿2022/02/10 03:32

Kome314

総合スコア20

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.30%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問