小编Nav*_*een的帖子

哪个先被调用?构造函数或 componentDidMount 或 Render

正如我在网上和官方文档中阅读的那样。顺序是 Constructor-> ComponentWillMount -> Render -> ComponentDidMount 等。

class Navigation extends Component {
    constructor(props) {
        super(props);
        console.log('constructor', this);
        this.state = { items: [ ] };
    }

componentDidMount() {
    console.log('componentDidMount');

    if ( toDisplay( ) ) {
        api.bringCats()
        .then( categories => {
            const tot_cat = categories.map( cat => { return {name: cat.name, link: cat.link}; })
            this.setState({items: tot_cat,})
        })
    }
}

render() { 
    console.log("render")
    //some stuff
}
}
Run Code Online (Sandbox Code Playgroud)

我希望日志按此顺序 1. 构造函数 2. ComponentDidMount 3. 渲染

this使用 constructor 内部构造函数方法进行日志记录。我能够获得价值,items因为componentDidMount …

javascript ecmascript-6 reactjs babeljs

5
推荐指数
1
解决办法
2148
查看次数

如何将加密形式的密码从ReactJS发送到ExpressJS?

const form = {
        firstname: "",
        lastname: "",
        email: "",
        password: "",
        gender: "",
        dob: "",
        username: ""
};

export default class Login extends React.Component {
  constructor (props) {
    super(props);
    this.handleSubmit = this.handleSubmit.bind(this);
    this.state = {
    }
  }

  handleSubmit (event) {
    event.preventDefault();
    api.signin(this.state)
  }

  handleChange (event, type) {
    form[type] = event.target.value;
    this.setState({
      form
    })
  }

  render() {
    return (
      <div>
        <nav className="navbar navbar-expand-md navbar-dark bg-dark fixed-top">
          <a className="navbar-brand" href="#">ChatBox</a>
          <button className="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarsExampleDefault">
            <span className="navbar-toggler-icon"></span>
          </button>

          <div className="collapse navbar-collapse" …
Run Code Online (Sandbox Code Playgroud)

javascript node.js reactjs nodemon

1
推荐指数
3
解决办法
8323
查看次数

标签 统计

javascript ×2

reactjs ×2

babeljs ×1

ecmascript-6 ×1

node.js ×1

nodemon ×1