React Hooks useEffect的使用

React Native+Taro+Typescript环境下:

TypeScript 复制代码
import React, { useState, useEffect } from 'react'
import { View, Text, Button } from '@tarojs/components'
import './index.scss'

const FlowersCard = ()=>{
  const [flowerName, setFlowerName] = useState('')
  const [flowerColor, setFlowerColor] = useState('')
  // 叶片个数
  const [bladeNum, setBladeNum] = useState(0)

  // 1. 无依赖 - 每次渲染后都执行
  useEffect(() => {
    console.log('组件渲染完成或组件更新后都会执行!')
  })

  // 2. 空依赖数组 - 仅在组件挂载时执行一次
  useEffect(() => {
    console.log('组件已挂载')
    
    // 模拟API调用
    const fetchFlowers = async () => {
      try {
        // 展示Loading并进行网络请求
        // 进行网络请求并获取页面中需要的数据
        setFlowerName(()=>'海棠')
        setFlowerColor(()=>'pink')
        setBladeNum(()=>50)
      } catch (error) {
        // 在这里隐藏Loading
      } finally {
        // 在这里隐藏Loading
      }
    }
    fetchFlowers()
    // 清理函数 - 组件卸载时执行
    return () => {
      console.log('组件即将卸载')
    }
  }, [])

  // 3. 有依赖项 - 当依赖项变化时执行
  useEffect(()=>{
    console.log("叶片的数量增加时,即bladeNum值改变时会触发这个函数的调用")
  }, [bladeNum])

  const addBladeNumber = ()=>{
    setBladeNum((preNum)=>{
      return preNum + 2
    })
  }

  return <View className='container'>
    <Text className='txt'>Flower Name is {flowerName}</Text>
    <Text className='txt'>Flower Color is {flowerColor}</Text>
    <Text className='txt'>flower Blade is {bladeNum}</Text>
    <Button className='btn' onClick={addBladeNumber}>增加叶片数量</Button>
  </View>
}

export default FlowersCard
相关推荐
知识分享小能手1 小时前
微信小程序入门学习教程,从入门到精通,微信小程序核心 API 详解与案例(13)
前端·javascript·学习·react.js·微信小程序·小程序·vue
蓝瑟4 小时前
React 项目实现拖拽排序功能,如何在众多库中选对 “它”
前端·javascript·react.js
小刘不知道叫啥5 小时前
React 源码揭秘 | 合成事件
前端·javascript·react.js
冰万森6 小时前
解决 React 项目初始化(npx create-react-app)速度慢的 7 个实用方案
前端·react.js·前端框架
千码君201610 小时前
React Native:关于react自定义css属性的位置
css·react native·react.js·前端框架·ecmascript·组件嵌套
小小前端_我自坚强11 小时前
React Hooks 使用详解
前端·react.js·redux
右子11 小时前
React 编程的优雅艺术:从设计到实现
前端·react.js·mobx
Dcc14 小时前
@tanstack/react-query详解 🔥🔥🔥React的异步数据管理神器
前端·react.js
多啦C梦a1 天前
React 实战:从 setInterval 到 useInterval,一次搞懂定时器 Hook(还能暂停!)
前端·javascript·react.js