反应页面空白,没有错误

如何解决反应页面空白,没有错误

我的 React 应用程序只显示一页的空白页。此页面适用于我的本地主机。但是,当我部署时,我似乎只得到一个空白页面,控制台日志、网络等中没有错误......

我的第一篇文章,感谢您的帮助。我将在下面发布详细信息。

Register/Complete 是有问题的路由。

App.js

  <ToastContainer />
<Switch>
  <Route exact path="/" component={Home} />
  <Route path="/login" component={Login} />
    <Route exact path="/register" component={Register} />
    **<Route path="/register/complete" component={RegisterComplete} />**
    <Route path="/forgot/password" component={ForgotPassword} />
    <Route exact path="/score" component={Score} />
    <Route exact path="/marketing" component={Marketing} />
    <Route path="/edit" component={Edit} />
    <Route path="/dashboard" component={Dashboard} />
    <Route path="/assistant" component={EAHome} />

    
    <Route exact path="/private" component={EAPrivate} />
    <Route path="/private/v5" component={EAPrivateTwo} />
    <Route path="/private/accidents" component={EAPrivateThree} />
     <Route path="/private/service" component={EAPrivateFour} />
      <Route path="/private/repairs" component={EAPrivateFive} />
      <Route path="/private/warrenty" component={EAPrivateSix} />



    <Route exact path="/dealer" component={EADealer} />
    <Route exact path="/dealer/damage" component={EADealerTwo} />
    <Route path="/dealer/work" component={EADealerThree} />
    <Route path="/dealer/repair" component={EADealerFour} />
    <Route path="/dealer/warrenty" component={EADealerFive} />
    <Route path="/dealer/viewing" component={EADealerSix} />

    <Route path="/checkout" component={Full} />
    <Route path="/vdi-check" component={Vdi} />



    <Route path="/password" component={Password} />
    <Route path="/shortlist" component={Shortlist} />
    
  </Switch>
  

注册Complete.js

const [email,setEmail] = useState("");
const [firstName,setFirstName] = useState("");
const [lastName,setLastName] = useState("");
const [displayName,setDisplayName] = useState("");
const [phoneNumber,setPhoneNumber] = useState("");
const [password,setPassword] = useState("");
const [password2,setPassword2] = useState("");
const [marketingAuth,setMarketingAuth] = useState(false);

//PREVENT
const { user } = useSelector((state) => ({ ...state }));


useEffect(() => {
    if (user && user.token) history.push('/');
},[user]);


useEffect(() => {
    setEmail(window.localStorage.getItem('emailForRegistration'))
    // console.log(window.location.href);
},[]);


const onSubmit = async e => {
    e.preventDefault();

    //valid
    if (!email || !password){
        toast.error('Email and password is required')
        return;
    }

    if (password.length < 6) {
        toast.error("Password must be 6 characters or above");
        return;
    }

    if(e.target.marketingAuth.checked){
          setMarketingAuth(true)
    }else{
        
    }

    // if (password !== password2) {
    //     console.log('passwords do not match','danger');
    // } else {

    //     // register({ email,firstName,lastName,phoneNumber,password}
    // }

    try {
        const result = await auth.signInWithEmailLink(email,window.location.href);
        if (result.user.emailVerified) {
            // Remove user email from local
            window.localStorage.removeItem("emailForRegistration");
            // Get User ID Token
            let user = auth.currentUser;
            await user.updatePassword(password);
            const idTokenResult = await user.getIdTokenResult();
            //REDUX
            console.log("TOKEN",idTokenResult);
            //redirect


            //MARKETING DATABASE 
            const config = {
                headers: {
                  'Content-Type': 'application/json'
                }
              }
            
              const body = JSON.stringify({ firstName,displayName,email,password,marketingAuth });
            
              try {
                const res = await Axios.post('/api/register',body,config);
            
                  console.log("RES DATA",res.data);
              } catch (error) {
                  console.log("ERROR:",error.message);
              }
            
            
            
            
            history.push('/');
        }
        // if(result.user.)
    } catch (error) {
    
        toast.error(error.message);
    }
}   


    return(
        <div className="containerscore">
        <div className="logincontain">
    <div class="page-header">
    <h1>Complete Sign Up</h1>
 </div>
     <form onSubmit={e => onSubmit(e)}>
        <div className="form-group">
            <label>Email*</label>
                    <input type="text"
                        placeholer="johndoe@gmail.com"
                        name='email'
                        value={email}

                       
                        className="form-control"
            />
        </div>
        <div className="form-group">
            <label>Display Name*</label>
                        <input type="text"
                            
                placeholer="john"
                name='displayName'
                value={displayName}
                onChange={(e) => setDisplayName(e.target.value)}
                minlength="1"
                            maxLength="18"
                            className="form-control"
                            required
          
            />
        </div>
        
        <div className="form-group">
        <label> Mobile Number (07 format)</label>
                        <input type="tel"
                            id="phone_num"
                            minlength="11"
                            maxLength="11"
                name='phoneNumber'
                value={phoneNumber}
                onChange={(e) => setPhoneNumber(e.target.value)}
                className="form-control"
          
            />
        </div>
        <div className="form-group">
            <label>Password*</label>
            <input type="password"
                placeholer="password"
                name='password'
                value={password}
                onChange={(e) => setPassword(e.target.value)}
  
                className="form-control"
           
            />
            </div>
            <div className="form-group">
            <label>Confirm Password*</label>
            <input type="password"
                placeholer="confirm password"
                name='password2'
                value={password2}
                onChange={(e) => setPassword2(e.target.value)}
           
                className="form-control"
           
            />
        </div>

        <div className="form-group">
            
                        <input type="checkbox"
                            name='marketingAuth'
                            value={marketingAuth}
                            onChange={(e) => setMarketingAuth(true)}
                
               
            /><label>Marketing Auth <Link to=''>Terms + Conditions's</Link></label>
        </div>

        <div className="form-group">
                    <input type="submit" value="Sign Up" className="btn btn-info"
                        />
        </div>



    </form>
    </div>
    </div>
);

新开发者,欢迎提出建议和批评。

谢谢。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-
参考1 参考2 解决方案 # 点击安装源 协议选择 http:// 路径填写 mirrors.aliyun.com/centos/8.3.2011/BaseOS/x86_64/os URL类型 软件库URL 其他路径 # 版本 7 mirrors.aliyun.com/centos/7/os/x86
报错1 [root@slave1 data_mocker]# kafka-console-consumer.sh --bootstrap-server slave1:9092 --topic topic_db [2023-12-19 18:31:12,770] WARN [Consumer clie
错误1 # 重写数据 hive (edu)&gt; insert overwrite table dwd_trade_cart_add_inc &gt; select data.id, &gt; data.user_id, &gt; data.course_id, &gt; date_format(
错误1 hive (edu)&gt; insert into huanhuan values(1,&#39;haoge&#39;); Query ID = root_20240110071417_fe1517ad-3607-41f4-bdcf-d00b98ac443e Total jobs = 1
报错1:执行到如下就不执行了,没有显示Successfully registered new MBean. [root@slave1 bin]# /usr/local/software/flume-1.9.0/bin/flume-ng agent -n a1 -c /usr/local/softwa
虚拟及没有启动任何服务器查看jps会显示jps,如果没有显示任何东西 [root@slave2 ~]# jps 9647 Jps 解决方案 # 进入/tmp查看 [root@slave1 dfs]# cd /tmp [root@slave1 tmp]# ll 总用量 48 drwxr-xr-x. 2
报错1 hive&gt; show databases; OK Failed with exception java.io.IOException:java.lang.RuntimeException: Error in configuring object Time taken: 0.474 se
报错1 [root@localhost ~]# vim -bash: vim: 未找到命令 安装vim yum -y install vim* # 查看是否安装成功 [root@hadoop01 hadoop]# rpm -qa |grep vim vim-X11-7.4.629-8.el7_9.x
修改hadoop配置 vi /usr/local/software/hadoop-2.9.2/etc/hadoop/yarn-site.xml # 添加如下 &lt;configuration&gt; &lt;property&gt; &lt;name&gt;yarn.nodemanager.res