React 18 中,定义变量、赋值和渲染的方式因变量的用途和作用域不同而有所差异,下面为你详细介绍不同场景下的实现方法。
1. 函数组件内定义普通变量
在函数组件里,你可以像在普通 JavaScript 函数中一样定义变量,并且这些变量会在每次组件重新渲染时重新创建。
import React from 'react';
const MyComponent = () => {
// 定义普通变量并赋值
const message = 'Hello, React 18!';
return (
<div>
{/* 渲染变量 */}
<p>{message}</p>
</div>
);
};
export default MyComponent;
2. 使用 useState Hook 定义状态变量
若要在组件中保存可以改变的数据,就需要使用 useState Hook。 useState 返回一个数组,包含当前状态值和一个用于更新状态的函数。
import React, { useState } from 'react';
const Counter = () => {
// 定义状态变量 count 并初始化为 0
const [count, setCount] = useState(0);
const increment = () => {
// 更新状态变量
setCount(count + 1);
};
return (
<div>
{/* 渲染状态变量 */}
<p>Count: {count}</p>
<button onClick={increment}>Increment</button>
</div>
);
};
export default Counter;
3. 使用 useRef Hook 定义可变变量
useRef 可以创建一个可变的对象,在组件的整个生命周期内保持不变。常用于存储不需要触发重新渲染的变量,例如 DOM 元素引用。
import React, { useRef } from 'react';
const InputComponent = () => {
// 定义一个可变变量 inputRef
const inputRef = useRef(null);
const handleClick = () => {
// 通过 inputRef.current 访问 DOM 元素
if (inputRef.current) {
inputRef.current.focus();
}
};
return (
<div>
<input ref={inputRef} type="text" />
<button onClick={handleClick}>Focus Input</button>
</div>
);
};
export default InputComponent;
const captchaUrls = useRef('');
<Image src={captchaUrls.current} alt="验证码" style={{ height: '32px',width: '100px' }} onClick={onCaptchaChange} />
4. 类组件中定义变量和状态
import React, { Component } from 'react';
class MyClassComponent extends Component {
constructor(props) {
super(props);
// 定义状态变量
this.state = {
message: 'Hello from Class Component!'
};
// 定义实例变量
this.counter = 0;
}
handleClick = () => {
// 更新状态变量
this.setState({
message: 'State updated!'
});
// 更新实例变量
this.counter++;
console.log('Counter:', this.counter);
};
render() {
return (
<div>
{/* 渲染状态变量 */}
<p>{this.state.message}</p>
<button onClick={this.handleClick}>Update State</button>
</div>
);
}
}
export default MyClassComponent;
总结
- - 普通变量 :适用于不需要在组件重新渲染时保留值的情况。
- - 状态变量 ( useState ) :用于存储会改变的数据,并且在数据更新时触发组件重新渲染。
- - 可变变量 ( useRef ) :用于存储不需要触发重新渲染的可变数据,如 DOM 元素引用。
- - 类组件变量 :在类组件中,可使用 this.state 存储状态,使用实例变量存储其他数据。