繁体   English   中英

无法在字符串“namangarg802@gmail.com”上创建属性“_canInitEmulator”

[英]Cannot create property '_canInitEmulator' on string 'namangarg802@gmail.com'

我在我的反应应用程序中为登录用户使用 firebase 身份验证,但是当我输入我的电子邮件“namangarg82@gmail.com”并单击“登录”按钮时,它显示一个错误:-无法在字符串上创建属性“_canInitEmulator” namangarg82@gmail.com' 我的 Signup.js 文件

import React, { useContext, useRef,useState} from 'react'
import { Form, Button, Card,Alert } from 'react-bootstrap'
import { useAuth } from './AuthContext';
import { AuthProvider } from './AuthContext';
export function Signup() {
    const emailRef=useRef();
    const passwordRef=useRef();
    const passwordConfirmRef=useRef();
    const { signup } =useAuth()
    const [error,setError]=useState('')
    const [loading,setLoading]=useState(false)
    console.log(error,"12",loading);
    console.log(useAuth(),"ji")
    // const{a}=useContext(AuthProvider);
    // console.log(a);
    async function handleSubmit(e){
        e.preventDefault()
        if(passwordRef.current.value!==passwordConfirmRef.current.value)
        {
            console.log(passwordRef.current.value);
            return setError("Passwords do not match")
           
        }
        try{
            console.log("try");
            setLoading(true);
            setError("");
            console.log(emailRef.current.value,passwordRef.current.value);
            await signup(emailRef.current.value,passwordRef.current.value)
        }  catch(err){
            console.log("hi",err);
            setError("Failed to create an account")
        }
        setLoading(false);
        console.log(loading,"8");

    }
    return (
       
        <div>
            <Card>
                <Card.Body className="text-center mb-4">
                    <h2>SignUp</h2>
                    {error && <Alert variant="danger">{error}</Alert>}
                    <Form onSubmit={(e)=>{handleSubmit(e)} }>
                        <Form.Group id="email">
                            <Form.Label>Email</Form.Label>
                            <Form.Control type="email" ref={emailRef}>
                            </Form.Control>
                        </Form.Group>
                        <Form.Group id="password">
                            <Form.Label>Password</Form.Label>
                            <Form.Control type="password" ref={passwordRef}>
                            </Form.Control>
                        </Form.Group>
                        <Form.Group id="passwordConfirm">
                            <Form.Label>Password Confirmation</Form.Label>
                            <Form.Control type="password" ref={passwordConfirmRef}>
                            </Form.Control>
                        </Form.Group>
                        <Button disabled={loading} type="submit" className="w-100">Sign Up</Button>
                    </Form>
                </Card.Body>
            </Card>

        </div>
    )
}

export default Signup

我的 Authcontext 文件

import React,{createContext,useContext,useState,useEffect} from 'react'
import {auth} from '../Firebase'
import { createUserWithEmailAndPassword} from "firebase/auth";
// const AuthContext =React.createContext()
const AuthContext =createContext()
export function useAuth(){
    return useContext(AuthContext)
}
export function AuthProvider({children}) {
    const [currentUser,setCurrentUser]=useState()
    function signup(email,password){
        return createUserWithEmailAndPassword(email,password)
    }
    useEffect(() => {
      const unsuscribe =  auth.onAuthStateChanged(user=>{
            setCurrentUser(user)
        })
      return unsuscribe
    }, [])
    
    const value={
        currentUser,
        signup,
        
    }
    return (
        <div>
            < AuthContext.Provider value={value}>
            {children}
            </AuthContext.Provider>
        </div>
    )
}

export default AuthContext

我的firebase设置是

import { initializeApp } from "firebase/app";
import { getAuth } from "firebase/auth";

const firebaseConfig = {
  apiKey: "AIzaSyDLlZn08b5PlDpiqTQNxkyfpOPpz_6Gh8o",
  authDomain: "portfolio-279ef.firebaseapp.com",
  projectId: "portfolio-279ef",
  storageBucket: "portfolio-279ef.appspot.com",
  messagingSenderId: "778898179742",
  appId: "1:778898179742:web:7beb09bf995e5041de1d8f"
};
const Firebaseapp = initializeApp(firebaseConfig);
export const auth=getAuth();
export default  Firebaseapp;

请帮我

在 firebase 9.0^ 中,您尝试使用此方法,在几乎所有方法中,首先插入 auth 方法,然后从您的 firebase 设置导入。

//With your app initialized
import {getAuth} from 'firebase/auth'
...
const auth = getAuth()
return createUserWithEmailAndPassword(auth, email,password)

来源: https : //firebase.google.com/docs/auth/web/password-auth?hl=pt

使用新的 firebase 功能方法,您需要包含这样的auth参数:

createUserWithEmailAndPassword(auth, email, password)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM