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

本文介绍了React中状态(state)的概念及其在组件中的定义方法,包括如何通过构造函数设置初始状态,并利用setState方法更新状态来触发组件重新渲染。此外,还讲解了如何处理组件内的事件并确保事件处理函数中的this指向正确。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

1.定义状态

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

//设置组件
class Event extends React.Component {
    constructor(props) {
        super(props);
        // 设置 initial state
        this.state = {
            msg: "hello",
			count: 1
        };

    }
	render() {
	 return <div>
	 	<p>{this.state.msg}</p>
		<p>{this.state.count}</p>
	 </div>;
	}
}

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

整体代码:

import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import registerServiceWorker from './registerServiceWorker';


//设置组件
class Event extends React.Component {
    constructor(props) {
        super(props);
        // 设置 initial state
        this.state = {
            msg: "hello",
			count: 1
        };

    }
	render() {
	 return <div>
	 	<p>{this.state.msg}</p>
		<p>{this.state.count}</p>
	 </div>;
	}
}


ReactDOM.render(
    <div>
		<Event />
	</div>,
    document.getElementById('root')
);
registerServiceWorker();

2.事件修改状态

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

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

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

import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import registerServiceWorker from './registerServiceWorker';


//设置组件
class Event extends React.Component {
    constructor(props) {
        super(props);
        // 设置 initial state
        this.state = {
            msg: "hello",
			count: 1
        };

    }
	add(){
		var newcount=this.state.count+1;
		this.setState({count:newcount });
	}
	render() {
	 return <div>
	 	<p>{this.state.msg}</p>
		<p onClick={this.add.bind(this)}>{this.state.count}</p>
	 </div>;
	}
}


ReactDOM.render(
    <div>
		<Event />
	</div>,
    document.getElementById('root')
);
registerServiceWorker();

3.说说组件中的this

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

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

111945_hzf0_2352644.png

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

111313_d8lB_2352644.png

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

 

转载于:https://my.oschina.net/tbd/blog/1544654

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值