useEffect,useState 基本用法

import {useEffect,useState} from "react"

export const  SearchPanel = () =>{
    const [param,setParam] = useState({
        name:'',
        personId:''
    })
    const [users,setUsers] = useState([])
    const [list,setList]   = useState([])

        /*

        param 每次改变 都会请求
        async 会将其后的函数(函数表达式或 Lambda)的返回值封装成一个 Promise 对象,而 await 会等待这个 Promise 完成,并将其 resolve 的结果返回出来。
        如果它等到的是一个 Promise 对象,await 就忙起来了,它会阻塞后面的代码,等着 Promise 对象 resolve,然后得到 resolve 的值,作为 await 表达式的运算结果
        看到上面的阻塞一词,心慌了吧……放心,这就是 await 必须用在 async 函数中的原因。async 函数调用不会造成阻塞,它内部所有的阻塞都被封装在一个 Promise 对象中异步执行。
        async/await 的优势在于处理 then 链

        */}
     useEffect(()=>{
        fetch('').then(async response => {
            if(response.ok){
                setList(await response.json())
            }
        },[param])
     })
    return <from>

              {/*
                 下面 的对应解构赋值写法
                 setParam(Object.assign({},param,{name:evt.target.value}))

              */}
                <div>
                    <input type="text" value ={param.name} onChange{evt => setParam({
                    ...param,
                    name:evt.target.value
                    }) />
                    <select
                    value = {param.personId}
                    onChange{evt => setParam({
                                        ...param,
                                        personId:evt.target.value
                                        })
                    >
                        <option value="">负责人</option>
                        {
                            users.map(user => <option value={user.id}>{user.name}</option> )
                        }
                    </select>
                </div>


           </from>
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
useState是React Hooks提供的一个函数,用于在函数式组件中声明和使用状态。它接受一个初始值作为参数,并返回一个包含当前状态和更新状态的数组。useState的作用类似于类组件中的this.state和this.setState方法,但是在函数式组件中使用更加简洁方便。 useEffect也是React Hooks提供的一个函数,用于在函数式组件中执行副作用操作,比如订阅事件、发送网络请求、操作DOM等。它接受两个参数,第一个参数是一个回调函数,用于执行副作用操作,第二个参数是一个依赖数组,用于指定何时重新执行副作用操作。useEffect的作用类似于类组件中的生命周期方法,比如componentDidMount、componentDidUpdate和componentWillUnmount。 useCallback也是React Hooks提供的一个函数,用于在函数式组件中缓存回调函数。它接受一个回调函数和一个依赖数组作为参数,并返回一个经过缓存的回调函数。useCallback的作用是在依赖数组不变的情况下,避免不必要的函数重新创建,提高性能。 综上所述,useState用于声明和使用状态,useEffect用于执行副作用操作,而useCallback用于缓存回调函数。它们都是React Hooks提供的函数,可以在函数式组件中方便地使用。 <span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [搞懂React Hooks之 useState, useCallback, useEffect, useRef ,useMemo和useEffect](https://blog.csdn.net/qq_27401917/article/details/116699141)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [学习记录431@react之useStateuseEffectuseCallback](https://blog.csdn.net/weixin_44663675/article/details/119121498)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值