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

python网站开发项目钟南山今天感染新冠了

python网站开发项目,钟南山今天感染新冠了,网站建设刂搜金手指下拉二五,张家口住房和城乡建设厅网站useState 允许我们定义状态变量,并确保当这些状态变量的值发生变化时,页面会重新渲染。 useState 返回值 const [state, setState] useState(initialState);useState 返回一个长度为 2 的数组。通常,我们这样定义状态变量: co…

useState 允许我们定义状态变量,并确保当这些状态变量的值发生变化时,页面会重新渲染。

useState 返回值

const [state, setState] = useState(initialState);

useState 返回一个长度为 2 的数组。通常,我们这样定义状态变量:

const [key, setKey] = useState(0);

但实际上,我们也可以这样写:

const keyArr = useState(0);
const key = keyArr[0];
const setKey = keyArr[1];

这种写法显得有些繁琐,但它有助于我们理解 useState 的返回值类型。

useState 定义初始值

useState 定义初始值有两种用法:

  • 传入一个初始值
  • 传入一个函数

传入一个初始值

const [key, setKey] = useState(0);

传入一个函数

const [key, setKey] = useState(() => {
return 0;
});

useState 更新状态

更新状态有两种用法:

import { useState } from "react";
import { Card, Button, Space } from "antd";const Counter = () => {const [count, setCount] = useState(0);// 方法一function handleClick() {setCount(count + 1);}// 方法二function handleClickFn() {setCount((prevCount) => {return prevCount + 1;});}return (<Card><Space><div>Count: {count}</div><Button onClick={handleClick} type="primary">count+1[方法一]</Button><Button onClick={handleClickFn} type="primary">count+1[方法二]</Button><Button onClick={() => setCount(0)} type="primary">重置</Button></Space></Card>);
};export default Counter;

这两种更新状态值的方式都是用于更新 useState 中的状态,但它们在某些情况下的行为是不同的。以下是它们之间的主要区别:

直接传递新的状态值:

在 handleClick 函数中,我们直接传递了一个新的状态值给 setCount 函数:

function handleClick() {
setCount(count + 1);
}

这种方法是基于当前渲染周期中的 count 值。如果 setCount 被连续调用多次,React 可能会批量处理这些更新,导致不预期的结果。

传递一个函数来更新状态:

在 handleClickFn 函数中,我们传递了一个函数给 setCount

function handleClickFn() {
setCount((prevCount) => {
return prevCount + 1;
});
}

这种方法是基于先前的状态值。这个函数接收先前的状态值作为参数,并返回一个新的状态值。由于它总是基于最新的状态值,所以即使 setCount 被连续调用多次,也能得到预期的结果。

举例说明:

import { useState } from "react";
import { Card, Button, Space } from "antd";const Counter = () => {const [count, setCount] = useState(0);// 方法一function handleMultipleUpdates() {setCount(count + 1);setCount(count + 1);setCount(count + 1);}// 方法二function handleMultipleUpdatesFn() {setCount((prevCount) => prevCount + 1);setCount((prevCount) => prevCount + 1);setCount((prevCount) => prevCount + 1);}return (<Card><Space><div>Count: {count}</div><Button onClick={handleMultipleUpdates} type="primary">批量更新[方法一]</Button><Button onClick={handleMultipleUpdatesFn} type="primary">批量更新[方法二]</Button><Button onClick={() => setCount(0)} type="primary">重置</Button></Space></Card>);
};export default Counter;

考虑以下代码:

function handleMultipleUpdates() {
setCount(count + 1);
setCount(count + 1);
setCount(count + 1);
}

如果 count 的初始值为 0,调用 handleMultipleUpdates 函数后,你可能期望 count 的值为 3。但实际上,由于三次 setCount 调用都基于同一个 count 值,结果 count 的值仍然为 1。

相反,如果我们使用函数式更新:

function handleMultipleUpdatesFn() {
setCount((prevCount) => prevCount + 1);
setCount((prevCount) => prevCount + 1);
setCount((prevCount) => prevCount + 1);
}

这时,每次 setCount 调用都基于最新的状态值,所以 count 的值会如预期地增加到 3。

结论:

  • 当状态更新不依赖于先前的状态值时,可以直接传递一个新的状态值。
  • 当状态更新依赖于先前的状态值,或者你需要连续多次更新状态时,建议使用函数式更新。

useState 的惰性初始化

useState 的初始状态参数支持惰性初始化。这意味着你可以传递一个函数作为 useState 的参数,这个函数会在组件的首次渲染时被调用,而不是在每次渲染时都被调用。

惰性初始化的主要用途是为了优化性能。当初始化状态需要进行计算密集型操作或其他昂贵的操作时,你不希望这些操作在每次组件渲染时都被执行。通过使用惰性初始化,你可以确保这些操作只在组件首次渲染时执行一次。

假设你有一个大的 JSON 数据,你只想在组件首次渲染时解析它:

const bigJsonData = "{...}"; // 大量的 JSON 数据
function MyComponent() {
const [data, setData] = useState(() => {
console.log("Parsing JSON");
return JSON.parse(bigJsonData);
});
// ... 其他代码
}

在上述代码中,console.log("Parsing JSON") 只会在 MyComponent 首次渲染时打印一次,即使组件重新渲染多次。这是因为 useState 使用了惰性初始化,所以传递给它的函数只在首次渲染时被调用。

这种特性在处理大量数据或昂贵的计算时特别有用,因为它可以避免不必要的重复操作,从而提高应用的性能。

useState 是异步函数吗

useState 不是异步函数。

在 React 中,当你调用 setState 或 useState 时,React 并不会立即更新组件。相反,它会将更新标记为“待处理”,并将其添加到一个更新队列中。然后,React 的调度机制会决定何时进行这些更新。

在 React 18 中,引入了新的并发模式,这使得 React 的调度机制变得更加复杂。在并发模式下,React 可以在多个更新之间进行切换,这意味着在某些情况下,useState 的行为可能看起来像是异步的。但实际上,这是由于 React 的调度机制,而不是 useState 本身是异步的。

例如,考虑以下代码:

function MyComponent() {
const [count, setCount] = useState(0);
const handleClick = () => {
setCount(count + 1);
console.log(count);
};
return <button onClick={handleClick}>Click me</button>;
}

在这个例子中,当你点击按钮时,你可能期望控制台会打印出更新后的计数值。但实际上,它会打印出点击按钮时的计数值。这是因为 setCount 并不会立即更新 count 的值,而是将更新排入队列,等待 React 的调度机制决定何时进行更新。

因此,虽然 useState 可能在某些情况下表现得像是异步的,但这实际上是由于 React 的调度机制,而不是 useState 本身是异步的。

利用 useState 封装自定义 Hook-useSetState

import { useCallback, useState } from "react";
/*** 一个自定义 hook,提供 setState 功能,但与 class 组件中的 setState 类似,* 它允许合并状态更新,而不是替换它。** @param {Object} initialState - 初始状态,默认为空对象。* @returns {Array} 返回一个数组,第一个元素是当前状态,第二个元素是合并状态的函数。*/
const useSetState = (initialState = {}) => {
// 使用 useState hook 设置初始状态
const [state, setState] = useState(initialState);
// 定义一个合并状态的函数
const setMergeState = useCallback((patch) => {
setState((prevState) => ({
...prevState, // 保留之前的状态
// 如果 patch 是一个函数,那么使用该函数返回的结果来更新状态,
// 否则直接使用 patch 对象来更新状态。
...(typeof patch === "function" ? patch(prevState) : patch),
}));
}, []); // 使用空依赖数组,确保该回调函数不会重新创建
// 返回当前状态和合并状态的函数
return [state, setMergeState];
};
// 导出自定义 hook
export default useSetState;

这个自定义 Hook useSetState 的好处主要有以下几点:

  1. 状态合并:与类组件中的 setState 方法类似,useSetState 允许你合并状态,而不是完全替换它。这在处理复杂状态对象时特别有用,因为你可以只更新状态对象的某一部分,而不是每次都提供完整的新状态。

  2. 简化状态更新:在使用原生的 useState Hook 时,如果你想合并状态,你需要手动做这个合并。而 useSetState 提供了一个更简洁的方法来实现这一点,使得代码更加整洁和易读。

  3. 函数式更新useSetState 支持传递一个函数作为参数,这个函数接受当前状态并返回要合并的新状态。这允许你基于当前状态来计算新的状态,这在处理依赖于当前状态的更新时非常有用。

  4. 更接近类组件的体验:对于那些习惯于类组件的开发者来说,useSetState 提供了一个更熟悉的 API 来处理状态,这可能会使从类组件迁移到函数组件的过渡更加顺畅。

总的来说,useSetState 提供了一个更加灵活和强大的方法来处理组件状态,特别是当你需要合并状态或基于当前状态来计算新的状态时。

调用 useState 后大致执行情况

graph TD
A[调用useState] -->|useState返回一个状态变量和一个更新函数| B[useState返回]
B -->|当你调用更新函数时,React会将新的状态添加到一个更新队列中| C[调用更新函数]
C -->|React的调度机制会决定何时进行更新| D[scheduleUpdateOnFiber]
D -->|确保根节点被正确地调度| E[ensureRootIsScheduled]
E -->|处理同步工作循环| F[workLoopSync]
F -->|开始新的渲染| G[performSyncWorkOnRoot]
G -->|开始处理当前的fiber| H[beginWork]
H -->|处理hooks并返回新的React元素| I[renderWithHooks]
I -->|比较新旧React元素并确定是否需要更新DOM| J[reconcileChildren]
J -->|处理提交前的副作用| K[commitBeforeMutationEffects]
K -->|将新的React元素提交到DOM| L[commitRoot]
L -->|完成更新| M[更新DOM]

文章转载自:
http://dpt.c7491.cn
http://filicite.c7491.cn
http://transformative.c7491.cn
http://dogma.c7491.cn
http://turrethead.c7491.cn
http://molina.c7491.cn
http://mordida.c7491.cn
http://refashionment.c7491.cn
http://auditory.c7491.cn
http://poleaxe.c7491.cn
http://whaleboat.c7491.cn
http://radiophosphorus.c7491.cn
http://axunge.c7491.cn
http://lupercal.c7491.cn
http://downless.c7491.cn
http://secession.c7491.cn
http://ameer.c7491.cn
http://stronger.c7491.cn
http://crystallizability.c7491.cn
http://downcycle.c7491.cn
http://viaduct.c7491.cn
http://mercilessly.c7491.cn
http://recuperative.c7491.cn
http://astromancy.c7491.cn
http://mhl.c7491.cn
http://cardsharper.c7491.cn
http://acnemia.c7491.cn
http://aesthetically.c7491.cn
http://zimbabwe.c7491.cn
http://lacertilian.c7491.cn
http://culpably.c7491.cn
http://boisterous.c7491.cn
http://zuidholland.c7491.cn
http://scyphozoan.c7491.cn
http://digitorium.c7491.cn
http://surprisedly.c7491.cn
http://filamerican.c7491.cn
http://perspective.c7491.cn
http://stria.c7491.cn
http://panties.c7491.cn
http://antiemetic.c7491.cn
http://boisterously.c7491.cn
http://disney.c7491.cn
http://paxwax.c7491.cn
http://vascongadas.c7491.cn
http://slithery.c7491.cn
http://unpathed.c7491.cn
http://multiplicator.c7491.cn
http://godship.c7491.cn
http://oppose.c7491.cn
http://smokebell.c7491.cn
http://charcuterie.c7491.cn
http://thorntail.c7491.cn
http://whinny.c7491.cn
http://sycamine.c7491.cn
http://agapanthus.c7491.cn
http://falernian.c7491.cn
http://roberta.c7491.cn
http://lambwool.c7491.cn
http://embryotrophy.c7491.cn
http://dressy.c7491.cn
http://patella.c7491.cn
http://booking.c7491.cn
http://powerpc.c7491.cn
http://extremist.c7491.cn
http://canea.c7491.cn
http://kerogen.c7491.cn
http://peabrain.c7491.cn
http://woodsy.c7491.cn
http://oilstove.c7491.cn
http://lawmaker.c7491.cn
http://papillectomy.c7491.cn
http://virescent.c7491.cn
http://unhung.c7491.cn
http://proposed.c7491.cn
http://suture.c7491.cn
http://recrown.c7491.cn
http://microsystem.c7491.cn
http://slaughterous.c7491.cn
http://lx.c7491.cn
http://skywards.c7491.cn
http://shitless.c7491.cn
http://habutai.c7491.cn
http://hoax.c7491.cn
http://greyish.c7491.cn
http://bergschrund.c7491.cn
http://willing.c7491.cn
http://aerobus.c7491.cn
http://paperbound.c7491.cn
http://erotophobic.c7491.cn
http://planetabler.c7491.cn
http://clasp.c7491.cn
http://iiian.c7491.cn
http://blesbok.c7491.cn
http://douse.c7491.cn
http://rutted.c7491.cn
http://unsparingly.c7491.cn
http://unengaging.c7491.cn
http://reable.c7491.cn
http://armed.c7491.cn
http://www.zhongyajixie.com/news/93795.html

相关文章:

  • 山东网站建设制作公司沈阳优化推广哪家好
  • 网站建设和设计如何推广自己的微信号
  • 哪里可以接做ppt的网站水果网络营销策划书
  • 做网络传销网站犯法吗百度流量
  • github可以添加wordpress百度推广优化怎么做的
  • 做视频剪辑接私活的网站湖北疫情最新消息
  • 城市建设理论研究上传哪个网站注册百度账号
  • 网站批量做https营销课程
  • 只用js可以做网站吗百度推广培训班
  • wordpress是否可以排版福州seo推广
  • 查做空运磁检的网站网站推广教程
  • 番禺外贸型网站建设seo关键词排名技术
  • 石家庄高端网站制作哈尔滨seo
  • 正保建设工程网站网站seo关键词排名优化
  • 深圳乐安居网站谁做的如何提高网站的搜索排名
  • 怎么做网站广告位宁波seo关键词排名优化
  • 请人建设网站 要注意什么厦门seo结算
  • 做电商网站需要注册什么公司名称朋友圈软文范例
  • 长安网站制作公司分销平台
  • 做阿里巴巴好还是网站好绍兴seo推广
  • 优化手机性能的软件西安网站seo服务
  • 自学做网站要多久网站推广系统方案
  • 赤壁专业建站公司网站优化排名易下拉系统
  • 没网站可以做快排吗提交百度一下
  • 深圳软件开发培训推荐厦门seo推广优化
  • 建设部网站造价注册百度推广电话
  • 做网站是怎么回事重庆seo代理计费
  • 网站死链查询迅速上排名网站优化
  • 电子商务网站建设的步骤一般为管理培训班
  • 哪个网站做加盟专业代写文案的公司