react学习笔记5:状态和组件this

前端之家收集整理的这篇文章主要介绍了react学习笔记5:状态和组件this前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

什么是状态?就是组件默认要使用的数据

1.定义状态

在定义组件,我们知道使用的是子类继承父类的方式,我们直接在构造函数中设置即可:

  1. //设置组件
  2. class Event extends React.Component {
  3. constructor(props) {
  4. super(props);
  5. // 设置 initial state
  6. this.state = {
  7. msg: "hello",count: 1
  8. };
  9.  
  10. }
  11. render() {
  12. return <div>
  13. <p>{this.state.msg}</p>
  14. <p>{this.state.count}</p>
  15. </div>;
  16. }
  17. }

这样,this.state就有绑定的各种初始化状态值了

整体代码

  1. import React from 'react';
  2. import ReactDOM from 'react-dom';
  3. import './index.css';
  4. import registerServiceWorker from './registerServiceWorker';
  5.  
  6.  
  7. //设置组件
  8. class Event extends React.Component {
  9. constructor(props) {
  10. super(props);
  11. // 设置 initial state
  12. this.state = {
  13. msg: "hello",count: 1
  14. };
  15.  
  16. }
  17. render() {
  18. return <div>
  19. <p>{this.state.msg}</p>
  20. <p>{this.state.count}</p>
  21. </div>;
  22. }
  23. }
  24.  
  25.  
  26. ReactDOM.render(
  27. <div>
  28. <Event />
  29. </div>,document.getElementById('root')
  30. );
  31. registerServiceWorker();

2.事件修改状态

react为我们提供了修改状态的api,就是继承父类而来的,

this.setState({状态名字:修改的值});

很简单,我们还是用click事件去操作,然后让count+1处理:

  1. import React from 'react';
  2. import ReactDOM from 'react-dom';
  3. import './index.css';
  4. import registerServiceWorker from './registerServiceWorker';
  5.  
  6.  
  7. //设置组件
  8. class Event extends React.Component {
  9. constructor(props) {
  10. super(props);
  11. // 设置 initial state
  12. this.state = {
  13. msg: "hello",count: 1
  14. };
  15.  
  16. }
  17. add(){
  18. var newcount=this.state.count+1;
  19. this.setState({count:newcount });
  20. }
  21. render() {
  22. return <div>
  23. <p>{this.state.msg}</p>
  24. <p onClick={this.add.bind(this)}>{this.state.count}</p>
  25. </div>;
  26. }
  27. }
  28.  
  29.  
  30. ReactDOM.render(
  31. <div>
  32. <Event />
  33. </div>,document.getElementById('root')
  34. );
  35. registerServiceWorker();

3.说说组件中的this

我们创建组件采用的是子类继承父类方法,可以使用构造函数,可以随便的书写,

在内部this就是类的this,代表创建的对象,我们随便使用是没有问题的,不过当我们绑定事件的时候,我们知道事件调用方法中this指向变化了,所以我们这么写就会出现错误

为了解决和事件this的冲突问题,我们需要在绑定事件调用方法的位置把类的this作为参数传递个调用方法

这时候的this就是代表类的this了,可以任意操作类中自定义的任何东西。

猜你在找的React相关文章