react的use函数可搭配Suspense与lazy

use 是一个用于解析 React v18 及以下版本的 promise 状态的 polyfill hook。请注意,它只实现了消费 promise 的能力。

参考资料

复制代码
https://www.reactuse.com/zh-Hans/state/use

https://zh-hans.react.dev/reference/react/use#dealing-with-rejected-promises

app.jsx

复制代码
import { useState, Suspense, lazy } from 'react';

const Son = lazy(() => delayForDemo(import('./Son.jsx')));

function fn1() {
  return new Promise((res) => {
    setTimeout(res, 1000, { a: { b: 33 } })
  })
}
async function fn2() {
  var res = await new Promise((res) => {
    setTimeout(res, 1000, 'bbbb')
  })
  return res
}
export default function MarkdownEditor() {

  const [dt1, sets] = useState(fn1);
  const [dt2, setb] = useState(fn2);

  return (
    <>
      <Suspense fallback={<div>loading...</div>}>
        <h2>Preview</h2>
        <Son dt1={dt1} dt2={dt2} />
      </Suspense>
    </>
  );
}

// Add a fixed delay so you can see the loading state
function delayForDemo(promise) {
  return new Promise(resolve => {
    setTimeout(resolve, 1200);
  }).then(() => promise);
}

son.jsx

复制代码
import { use } from 'react'
export default function MarkdownPreview({ dt1, dt2 }) {
  var d1 = use(dt1)
  var d2 = use(dt2)
  return (
    <>
      <h1>{dt1.a.b}</h1>
      <div>-------</div>
      <h1>{d2}</h1>
    </>
  );
}

只有等待fn1,fn2里的函数 resolve之后,才会显示Son组件

附:延迟promise时间
复制代码
延迟特定promise时间
function delay(ms) {
  return new Promise(resolve => setTimeout(resolve, ms));
}

delay(3000).then(() => alert('runs after 3 seconds'));
附:延迟组件加载时间
复制代码
//定义
function delayForComp(promise) {
  return new Promise(resolve => {
    setTimeout(resolve, 1200);
  }).then(() => promise);
}

//使用:
import { useState, Suspense, lazy } from 'react';

const Mxxxxx = lazy(() => delayForComp(import('./Mxxxxx.jsx')));



//放在Suspense内部
  return (
    <>
      <Suspense fallback={<div>loading...</div>}>
        <h2>Preview</h2>
        <Mxxxxx dt1={dt1} dt2={dt2} />
      </Suspense>
    </>
  );
相关推荐
2301_815645386 小时前
html.
前端·html
qq_381338506 小时前
CSS @layer 级联层实战指南:从样式冲突到分层架构
前端·css
广州华水科技6 小时前
深度测评2026年好用的单北斗GNSS变形监测系统推荐,提升GNSS位移监测精度,引领智能监控新风尚
前端
花归去7 小时前
vue3中 function getText(){} 、 const getText=()=>{} ;区别在哪里,优缺点
javascript·vue.js·ecmascript
ZC跨境爬虫7 小时前
跟着 MDN 学 HTML day_33:(Attr 接口与属性节点的深入理解)
前端·javascript·ui·html·音视频·html5
神所夸赞的夏天7 小时前
如何获取多层json数据,存成dictionary,并取最大最小值
java·前端·json
红色的小鳄鱼7 小时前
前端面试js手写
开发语言·前端·javascript
焦糖玛奇朵婷7 小时前
健身房预约小程序开发、设计
java·大数据·服务器·前端·小程序
上海云盾王帅7 小时前
WEB业务如何接入安全防护:从零到一的实战指南
前端·安全
用户059540174467 小时前
AI Agent记忆丢失踩坑实录:这个问题让我排查了3天
前端·css