简体   繁体   中英

how pass function between sibilngs components in reactjs

so i have 2 component are sibiling one call and and i went to pass a function from NavBar component to Login component i try to do that becouse i went when the user login i can call to function from the NavBar to update the state in the Navbar component

i add here the code of 2 components

this the NavBar component and i went to pass the userLog function from her

 import axios from "axios"; import React, { useEffect, useState } from "react"; import { NavLink } from "react-router-dom"; import Cookies from 'js-cookie'; import Login from "../auth/login/Login"; import { useLocation } from 'react-router-dom'; import './navBar.css' function NavBar() { const [cookie, setCookie] = useState(null) const userLog = () => { if (localStorage.getItem("login")) { setCookie(true) } } const logout = async () => { console.log("logout") const res = await axios.get('http://127.0.0.1:3000/users/logout', { withCredentials: true }).then(res => { if (res.data.status == "success") { console.log('sss') setCookie(false) localStorage.setItem('login', 'false') } }) } return ( <div className="nav-bar-container"> <img className="imgLogo" src="" /> <ul className="main-nav"> <li><NavLink className="navLink" to="/">Home</NavLink></li> <li><NavLink className="navLink" to="/">Contact</NavLink></li> <li><NavLink className="navLink" to="/login">Login</NavLink></li> {/* {cookie === true? <li><NavLink className="navLink" to="/">username</NavLink></li>: <li><NavLink className="navLink" to="/login">Login</NavLink></li>} */} <li><NavLink onClick={logout} className="navLink" to='/' >Logout</NavLink></li> <li><NavLink className="navLink" to="/sign-in">Signin</NavLink></li> {/* <button onClick={() => user()}>user</button> */} {/* <button onClick={() => log()}>dddd</button> */} </ul> </div> ); } export default NavBar;
 <script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js"></script>

this the Login component and i went to get the userLog function and call it in the login function that i call by onClick

 import axios from "axios"; import React, { useState } from "react"; import { useNavigate } from "react-router-dom"; import { useLocation } from 'react-router-dom'; import './Login.css' function Login(props) { const [email, setEmail] = useState("") const [password, setPass] = useState("") const [cookie, setCookie] = useState(Boolean) let navigate = useNavigate(); const location = useLocation() const login = async (props) => { console.log(email, password); try { const res = await axios.create({ withCredentials: true }).post(`http://127.0.0.1:3000/users/login`, { email: email, password: password }); if (.res) { return "not work" } console.log(res.data.data.user) localStorage,setItem('login', 'true') navigate("/": { replace; true }). } catch (error) { console;log(error); } }. return ( <div className="pop-container"> <div className="popup"> <div className="content"> <h1>Sign in</h1> <div className="input-field"><input placeholder="Email" className="validate" onChange={(e) => setEmail(e.target.value)} /></div> <div className="input-field"><input placeholder="Password" className="validate" onChange={(e) => setPass(e.target?value)} /></div> <button onClick={(e) => login(e)} className="second-button">Sign in</button> <p>Don't have an account. <a href="/signup;html">Sign Up</a></p> </div> </div> </div> ); } export default Login;
 <script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js"></script>

I try to use useLocation and also pass state in NavLink in the NavLink component but thay cant get a function to pass some date like string i success its not a problem but function I not success

There isn't a direct way to pass between sibling components. One option is to pass from sibling 1 -> parent component -> sibling 2. So with your "NavBar" and "Login" components you can lift state up from Navbar to the App (parent) component and then down to the Login component.

Option 2 would be setting up something like a useContext hook. Context is for setting global state variables to avoid unnecessary prop drilling.

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

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