gpt4 book ai didi

javascript - 划分 React.js 组件

转载 作者:行者123 更新时间:2023-11-29 18:52:37 24 4
gpt4 key购买 nike

这是我的 Navigation组件

import React from 'react';
import {Navbar, Nav, NavItem, Modal, Button, FormControl} from 'react-bootstrap';
import {BrowserRouter, Link, Route, Switch} from 'react-router-dom';
import Questions from './Questions';
import {About} from './About';
import {Home} from './Home';
import {LinkContainer} from 'react-router-bootstrap';
import Question from './Question';
import firebase from '../firebase';

class Navigation extends React.Component {
constructor(props) {
super(props);
this.state = {};
this.login = this.login.bind(this);
this.logout = this.logout.bind(this);
this.openLogin = this.openLogin.bind(this);
this.handleClose = this.handleClose.bind(this);
}

componentDidMount() {
firebase.auth().onAuthStateChanged(user => {
if (user) {
console.log(user);
this.setState(
{
user: user
}, () => this.props.checkUserState(this.state.user)
);
}
});
}

logout() {
firebase.auth().signOut()
.then(() => {
this.setState({
user: null
}, function () {
this.props.checkUserState(this.state.user)
});
});
}

login() {
var email = document.getElementById('email').value;
var password = document.getElementById('password').value;
firebase.auth().signInWithEmailAndPassword(email, password)
.then(result => {
const user = result.user;
this.setState({
user: user,
},
function () {
this.props.checkUserState(this.state.user)
});
document.getElementById('close').click();
document.getElementById('questions').click();
}
).catch(e => console.log(e));
}

openLogin() {
this.setState({show: true});
}

handleClose() {
this.setState({show: false});
}

render() {
return (
<React.Fragment>
<BrowserRouter>
<React.Fragment>
<Navbar>
<Navbar.Header>
<Navbar.Brand>
<Link id='home' to="/">UczIchApp</Link>
</Navbar.Brand>
</Navbar.Header>
<Nav>
<LinkContainer id='about' to='/about'>
<NavItem>O nas</NavItem>
</LinkContainer>
{
this.state.user ?
<React.Fragment>
<LinkContainer id="questions" to='/questions'>
<NavItem>Zadania</NavItem>
</LinkContainer>
<NavItem onClick={this.logout}>Wyloguj się</NavItem>
</React.Fragment>
:
<NavItem onClick={this.openLogin}>Zaloguj się</NavItem>
}
</Nav>
</Navbar>
<Switch>
<Route exact path="/about" component={About}/>
<Route exact path="/questions" component={Questions}/>
<Route exact path="/" component={Home}/>
<Route path='/question/:id' component={Question}/>
</Switch>
</React.Fragment>
</BrowserRouter>
<Modal
show={this.state.show}
onHide={this.handleClose}>
<Modal.Header
closeButton>
<Modal.Title> Modal
heading </Modal.Title>
</Modal.Header>
<Modal.Body>
<form>
<FormControl
id="email"
type="email"
label="Email address"
placeholder="Enter email"/>
<FormControl id="password" label="Password" type="password"/>
<Button onClick={this.login}>Zaloguj</Button>
</form>
</Modal.Body>
<Modal.Footer>
<Button id="close" onClick={this.handleClose}>Close</Button>
</Modal.Footer>
</Modal>
</React.Fragment>
)
}
}

export default Navigation;

如您所见,这个 Navigation组件做的事情太多了。我想把它分开,但当我尝试时,我发现其中有很多联系。

例如,我尝试使用 Modal到一个单独的组件,但随后我需要将所有登录逻辑移入其中,所以我认为这有点毫无意义,因为要使用 userNavigation组件我只需要将整个代码移动到新文件,从而重现问题。

我知道这是一种错误的代码编写方式,我不会要求为我重写它,但如果有人经历过它可以给我关于如何划分它的几个技巧,我可以自己做。

我在想什么:移动Modal到不同的组件并将所有登录和注销逻辑移动到不同的组件。问题是我把它全部链接在一个文件中。我现在该如何解决?

我所说的链接是指我对这里的所有内容都使用一个状态对象。

最佳答案

您将在许多 React 项目中看到的一个常见模式是将容器组件与展示器组件分开。在您的情况下,剥离一些 Presenter 组件来分解您的应用程序相当容易。

阅读文档,尤其是 Lifting State UpThinking in React如果您还没有这样做。它很好地解释了这些概念。

关于javascript - 划分 React.js 组件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50719671/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com