尚硅谷react教程_扩展_stateHook

1.类式组件写

javascript 复制代码
import React, {Component} from 'react';

export default class Demo extends Component {
    state = {count:0}
    add = () => {
        this.setState(state=>({
            count:state.count+1
        }))
    }
    render() {
        return (
            <div>
                <h2>当前求和为{this.state.count}</h2>
                <button onClick={this.add}>点我+1</button>
            </div>
        );
    }
}

2.函数式组件写的

javascript 复制代码
import React from 'react';

// 函数式组件
function Demo() {
    const [count,setCount] = React.useState(0)
    const [name,setName] = React.useState('tom')

    // 加的回调
    function add() {
        // setCount(count+1) // 第一种写法
        // setCount((count)=>{ // 第二种写法
        //     return count+1
        // })

        setCount(count=> count+1) // 第二种写法的简写方式
    }

    // 修改名字
    function changeName() {
        setName('jack')
    }
    return (
        <div>
            <h2>当前求和为:{count}</h2>
            <h2>我的名字为:{name}</h2>
            <button onClick={add}>点我+1</button>
            <button onClick={changeName}>点我改名</button>
        </div>
    )
}

export default Demo;
复制代码
State Hook
(1)State Hook让函数组件也可以有state状态,并进行状态数据的读写操作做
(2)语法:const [xxx,setXxx] = React.useState(initValue)
(3)useState()说明:
    参数:第一次初始化指定的值在内部作缓存
    返回值:包含2个元素的数组,第一个为内部当前状态值,第二个为更新状态值的函数
(4)setXxx()2种写法:
    setXxx(newValue):参数为非函数值,直接指定新的状态值,内部用其覆盖原来的状态值
    setXxx(value => newValue):参数为函数,接收原来的状态值,返回新的状态值,内部用其覆盖原来的状态值
相关推荐
nixiaoge18 分钟前
Web前端第二次作业
前端·javascript·css3
安冬的码畜日常22 分钟前
【玩转 Postman 接口测试与开发2_005】第六章:Postman 测试脚本的创建(上)
javascript·测试工具·单元测试·postman·bdd·chai
浮华似水29 分钟前
Docker入门系列——镜像原理
前端
Gavin_91532 分钟前
【JavaScript】数组-集合-Map-对象-Class用法一览
开发语言·前端·javascript
张保瑞1 小时前
十一:java web(3)-- Spring框架 -- Spring简介
java·前端·spring
墨柳烟1 小时前
ABAQUS高亮显示网格节点方法:Python为每个节点建立集合
开发语言·前端·python·abaqus
琴~~2 小时前
前端根据后端返回的文本流逐个展示文本内容
前端·javascript·vue
zhaocarbon2 小时前
el-scrollbar 动态更新内容 鼠标滚轮无效
前端·javascript·vue.js
一纸忘忧2 小时前
Nuxt 3.14 发布!全新功能与性能提升
前端·javascript·vue.js
少年姜太公2 小时前
【ES6】让你彻底搞懂const ,let和var的区别
javascript