【04】基础知识:React组件实例三大核心属性 - state

news/2024/7/15 17:37:41 标签: react.js, 前端, javascript

一、state 了解

理解

1、state 是组件对象最重要的属性,值是对象(可以包含多个 key-value 的组合)

2、组件被称为 “状态机”, 通过更新组件的 state 来更新对应的页面显示(重新渲染组件)

强烈注意

1、组件中 render 方法中的 this 为组件实例对象

2、组件自定义的方法中 this 为 undefined,如何解决?

a)、强制绑定 this:通过函数对象的 bind()

b)、自定义方法使用:赋值语句+箭头函数

3、状态数据,不能直接修改或更新,需要通过 setState 方法进行修改

二、案例

定义一个展示天气信息的组件,默认展示天气炎热 或 凉爽,点击文字切换天气

基础写法(了解)

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>state</title>
</head>
<body>
	<!-- 准备好一个“容器” -->
	<div id="test"></div>
	
	<!-- 引入react核心库 -->
	<script type="text/javascript" src="../js/react.development.js"></script>
	<!-- 引入react-dom,用于支持react操作DOM -->
	<script type="text/javascript" src="../js/react-dom.development.js"></script>
	<!-- 引入babel,用于将jsx转为js -->
	<script type="text/javascript" src="../js/babel.min.js"></script>

	<script type="text/babel">javascript">
		// let that // ********了解:定义变量,缓存this

		// 1、创建组件
		class Weather extends React.Component {
			// 构造器调用几次?———— 1次,实例化组件时调用
			constructor(props) { // props为组件三大属性二,后续学习
				console.log('constructor')
				super(props)
				// 初始化状态
				this.state = { isHot: false, wind: '微风' }
				// that = this // ********了解:赋值this给that

				// 解决changeWeather中this指向问题(获取原型上的changeWeather,修改this指向为实例对象,返回新函数,挂载在实例自身)
				this.changeWeather = this.changeWeather.bind(this)
			}

			// render调用几次?———— 1+n次,实例化组件时调用1次、n是状态更新的次数
			render() {
				console.log('render')
				const { isHot, wind } = this.state
				return <h2 onClick={ this.changeWeather }>今天天气很 { isHot ? '炎热' : '凉爽' }{ wind }</h2>

				// ********了解:定义changeWeather在类外部
				// return <h2 onClick={changeWeather}>今天天气很 { isHot ? '炎热' : '凉爽' }, { wind }</h2>
			}

			// changeWeather调用几次?———— 点几次调几次
			changeWeather() {
				// changeWeather放在哪里?———— Weather的原型对象上,供实例使用
				// console.log(this) // undefined
				// 由于changeWeather是作为onClick的回调,所以不是通过实例调用的,是直接调用
				// 类中的方法默认开启了局部的严格模式,所以changeWeather中的this为undefined
				console.log('changeWeather')

				const { isHot } = this.state
				// 严重注意:状态必须通过setState进行更新,且更新是一种合并,不是替换。
				this.setState({ isHot: !isHot })

				// 严重注意:状态(state)不可直接更改
				// this.state.isHot = !isHot // 错误写法,React中值未改变
			}
		}

		// 2、渲染组件到页面
		ReactDOM.render(<Weather/>, document.getElementById('test'))

		 // ********了解:定义在类外部,一般不这么写
		// function changeWeather() {
		// 	console.log(this) // this为undefined,因为babel会将jsx转换为严格模式,严格模式下自定义函数中this为undefined
		// 	console.log(that.state)
		// }
	</script>
</body>
</html>

简化写法(常用)

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>state简写方式</title>
</head>
<body>
	<!-- 准备好一个“容器” -->
	<div id="test"></div>
	
	<!-- 引入react核心库 -->
	<script type="text/javascript" src="../js/react.development.js"></script>
	<!-- 引入react-dom,用于支持react操作DOM -->
	<script type="text/javascript" src="../js/react-dom.development.js"></script>
	<!-- 引入babel,用于将jsx转为js -->
	<script type="text/javascript" src="../js/babel.min.js"></script>

	<script type="text/babel">javascript">
		// 1、创建组件
		class Weather extends React.Component {
			// constructor构造器不需要时可省略

			// 初始化状态:类中可以直接写赋值语句,如下代码的含义是:给Weather的实例对象添加一个属性state
			state = { isHot: false, wind: '微风' }

			render() {
				const { isHot, wind } = this.state
				return <h2 onClick={ this.changeWeather }>今天天气很 { isHot ? '炎热' : '凉爽' }{ wind }</h2>
			}

			// 自定义方法:要用赋值语句的形式(将changeWeather放在实例对象上,而不是原型对象上)+ 箭头函数(箭头函数没有this,指向父级的this,为实例对象)
			changeWeather = () => {
				console.log(this)
				const { isHot } = this.state
				this.setState({ isHot: !isHot })
			}
		}

		// 2、渲染组件到页面
		ReactDOM.render(<Weather/>, document.getElementById('test'))
	</script>
</body>
</html>

三、原生事件绑定方法

1、element.addEventListener(事件名, 方法)

2、element.onclick = 方法

3、直接在标签上绑定

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8" />
		<title>Document</title>
	</head>
	<body>
		<button id="btn1">按钮1</button>
		<button id="btn2">按钮2</button>
		<button onclick="javascript language-javascript">demo()">按钮3</button>

		<script type="text/javascript">javascript">
			const btn1 = document.getElementById('btn1')
			btn1.addEventListener('click', () => {
				alert('按钮1被点击了')
			})

			const btn2 = document.getElementById('btn2')
			btn2.onclick = () => {
				alert('按钮2被点击了')
			}

			function demo(){
				alert('按钮3被点击了')
			}
		</script>
	</body>
</html>

注意:

React 对原生 javascript 中所有的事件做了一层封装

比如,onclick 在 React 中需要写为 onClick


http://www.niftyadmin.cn/n/5085976.html

相关文章

NumPy入门文档

当谈到Python中用于数值计算和数据处理的工具包时&#xff0c;NumPy&#xff08;Numerical Python&#xff09;是一个不可或缺的库。NumPy提供了强大的多维数组对象和一系列函数&#xff0c;使得在Python中执行高性能数学运算变得更加容易。本篇技术博客将总结NumPy的主要知识点…

Java新特性Stream流详解

一、概述 Stream流是Java 8 API添加的一个新的抽象&#xff0c;以一种声明性方式处理数据集合&#xff08;侧重对于源数据计算能力的封装&#xff0c;并且支持序列与并行两种操作方式&#xff09;。 Stream流是对集合&#xff08;Collection&#xff09;对象功能的增强&#xf…

ue5蓝图请求接口

安装与使用 1、在虚幻商城搜索 VaRest 插件 2、选择自己项目的对应版本安装 3、查看是否安装成功 4、进入项目后,分别启动VaRest、JSON Blueprint Utilities两个插件(勾选后会提示重启项目) 5、基本用法:打开关卡蓝图使用(url改为自己的接口、Verb是请求方式) 5.1、或者…

Redis--List、Set、Zset、Hash、Bitmaps、HyperLogLog、Geospatial

List LPUSH key value1 [value2] 将一个或多个值插入到列表头部 127.0.0.1:6379> LPUSH myls1 1 (integer) 1 127.0.0.1:6379> LPUSH myls1 2 (integer) 2 127.0.0.1:6379> LRANGE myls1 0 -1 1) "2" 2) "1" LPOP key 移出并获取列表的第一个元素…

热风梳被亚马逊下架是什么原因,UL859测试报告解析

近期受到亚马逊严查UL认证的影响&#xff0c;有卖家反映自己的产品被亚马逊下架了&#xff0c;并且收到了一份邮件通知&#xff0c;由于产品缺少UL认证被删除listing。 现在亚马逊平台竞争也愈显激烈&#xff0c;不合规范的操作也越来越多&#xff0c;随之平台要求越来越高&…

【DRAM存储器十五】DDR介绍-关键技术之DLL和prefetch

&#x1f449;个人主页&#xff1a;highman110 &#x1f449;作者简介&#xff1a;一名硬件工程师&#xff0c;持续学习&#xff0c;不断记录&#xff0c;保持思考&#xff0c;输出干货内容 参考资料&#xff1a;《镁光DDR数据手册》 目录 DLL 预取 DDR SDRAM的几个新增时…

给电瓶车“消消火”——TSINGSEE青犀智能电瓶车棚监控方案

近年来&#xff0c;电瓶车电梯起火、室内起火、楼道起火的新闻层出不穷&#xff0c;很多人为了图方便就将电瓶车推到家中充电&#xff0c;这种十分危险的行为&#xff0c;严重影响了社区的公共安全和个人生命财产&#xff0c;为什么惨痛新闻不断播出&#xff0c;这种行为还是屡…

无限连接:前端跨页面通信的实现与应用

&#x1f3ac; 江城开朗的豌豆&#xff1a;个人主页 &#x1f525; 个人专栏 :《 VUE 》 《 javaScript 》 &#x1f4dd; 个人网站 :《 江城开朗的豌豆&#x1fadb; 》 ⛺️ 生活的理想&#xff0c;就是为了理想的生活 ! 目录 引言 1. 前端跨页面通信的概述 2. 前端跨页…