当前位置: 首页 > news >正文

React 18 如何定义变量,及赋值 与渲染

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 存储状态,使用实例变量存储其他数据。

相关文章:

  • python网络爬虫开发实战之网页数据的解析提取
  • docker常见的命令详细介绍
  • java小白日记38(集合-List)
  • 来源于胡椒的亚甲二氧桥CYP450-文献精读119
  • Android Window浮窗UI组件使用JetPack
  • 剑指 Offer II 111. 计算除法
  • 如何在 Linux 系统中部署 FTP 服务器:从基础配置到安全优化
  • Softmax温度调节与注意力缩放:深度神经网络中的平滑艺术
  • iStoreOS软路由对硬盘格式化分区(转化ext4)
  • Redisson分布式锁(超时释放及锁续期)
  • 已安装MFC,仍然提示“error MSB8041: 此项目需要 MFC 库”
  • 14:00面试,15:00就出来了,问的问题过于变态了。。。
  • golang errgroup用法介绍结合
  • [特殊字符] 2025蓝桥杯备赛Day8——B2118 验证子串
  • Cesium 自定义路径导航材质
  • c#知识点补充4
  • HTML5拖拽功能教程
  • C语言的结构体和C++的结构体 差异
  • 分析K8S中Node状态为`NotReady`问题
  • MySQL 中,聚合函数、连表查询、GROUP BY、ORDER BY、LIMIT 和 HAVING
  • 中山外贸网站开发/百度互联网营销
  • 查询网站是否备案/短视频培训学校
  • 怎样做淘宝客导购网站/如何在百度上添加店铺的位置
  • 外国人做旅游攻略网站/国际重大新闻事件2023
  • 宝安网站建设公司/sem公司
  • 广州做大型网站建设/站长工具是什么意思