如何在三元运算符上导航反应页面?

How to navigate react page on ternary operators?

如果 LoggedIn 和 admin 为真,我正在尝试导航到管理页面,同时向 /admin 发送道具,但这不起作用。你能帮忙吗?



export default function Auth() {


  function login(e) {
    e.preventDefault();
    const data = { email, password };
    axios
      .post("http://localhost:3001/api/Login", data, { withCredentials: true })
      .then((response) => {
      
      if(!!response.data.loggedIn && !!response.data.admin){ return( <Navigate to="/admin"  loggedIn={"response.data.loggedIn"} replace/> )}
     else if(!!response.data.loggedIn && ! !!response.data.admin){ window.location.href = "https://www.dummyweb.com/webmail";}
    else{return(alert("Username or Password is not valid!"))}  
    });
  
  }

  return (
    <div>
    <LogginForm/>
</div>
 )
}

可以使用react-router Redirect组件

return <>{props.isLoggedIn ?  (<div>
   <Row className={stylesadmin.root}> 
     <Uploader/>
     <ToastContainer/>  
   </Row>
 </div>) : <Redirect to='/Auth'/> }</>
}

您可以使用 Redirect 组件或使用 react-router-dom

中的 useHistory 挂钩

要有条件地呈现内容或重定向,您应该使用以下内容:

react-router-dom

由于您正在尝试使用 useNavigate 挂钩,我假设您正在使用 react-router-dom v6 并将从那里开始。

版本 6

Redirect 组件已在 react-router-dom v6 中删除。使用 Navigate 组件并指定 replace 道具进行重定向而不是正常导航。

export default function Admin(props) {
  return props.isLoggedIn ? (
    <div>
      <Row className={stylesadmin.root}> 
        <Uploader/>
       <ToastContainer/>  
      </Row>
    </div>
  ) : (
    <Navigate to="/Auth" replace />
  );
}

版本 5

使用 Redirect 组件重定向到“/Auth”。

export default function Admin(props) {
  return props.isLoggedIn ? (
    <div>
      <Row className={stylesadmin.root}> 
        <Uploader/>
       <ToastContainer/>  
      </Row>
    </div>
  ) : (
    <Redirect to="/Auth" />
  );
}

更新

使用命令式 navigation/redirect.

导入 useNavigate (v6) / useHistory (v5) 挂钩并发出命令式重定向。

export default function Auth() {
  const navigate = useNavigate();  // v6
  // const history = useHistory(); // v5

  function login(e) {
    e.preventDefault();
    const data = { email, password };

    axios
      .post("http://localhost:3001/api/Login", data, { withCredentials: true })
      .then((response) => {
        if (!!response.data.loggedIn && !!response.data.admin) {
          navigate(
            "/admin",
            {
              replace: true,
              state: { loggedIn: response.data.loggedIn },
            }
          );
          // history.replace(
          //   "/admin",
          //   {
          //     loggedIn: response.data.loggedIn,
          //   }
          // );
        } else if (!!response.data.loggedIn && ! !!response.data.admin) {
          window.location.href = "https://www.dummyweb.com/webmail";
        } else {
          alert("Username or Password is not valid!");
        }  
      });
  }

  return (
    <div>
      <LogginForm/>
    </div>
  );
}
import { useNavigate } from 'react-router-dom';
export default function Auth() {

  let navigate = useNavigate();
  function login(e) {
    e.preventDefault();
    const data = { email, password };
    axios
      .post("http://localhost:3001/api/Login", data, { withCredentials: true })
      .then((response) => {
      
      if(!!response.data.loggedIn && !!response.data.admin){ return(  navigate( "/admin" , { state:{loggedIn:response.data.loggedIn}} )}
     else if(!!response.data.loggedIn && ! !!response.data.admin){ window.location.href = "https://www.dummyweb.com/webmail";}
    else{return(alert("Username or Password is not valid!"))}  
    });
  
  }

  return (
    <div>
    <LogginForm/>
</div>
 )
}

在管理页面我处理如下

export default function Admin() {
  const {state} = useLocation();
 const { loggedIn} = state;

return(
loggedIn?
(<whatever/>):(<whatever2/>)
 )
}

这非常有效