首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >悬念不是在呈现反应之后加载内容。

悬念不是在呈现反应之后加载内容。
EN

Stack Overflow用户
提问于 2019-10-09 06:02:51
回答 1查看 8.3K关注 0票数 1

我使用的是reactjs的code-splitting延迟加载概念。但是<Suspense>似乎对我不起作用,因为它没有向我展示回退、加载消息和直接在它的渲染中加载代码。

我正在本地开发环境中运行react应用程序,而不使用它的生产版本。下面是我正在使用的代码。

代码语言:javascript
复制
import React,{ lazy, Suspense } from 'react';

class Homepage extends React.Component{
render(){
   return(
     <div>
       <Suspense fallback={<h2>Products are loading...</h2>}>
          // products display code
       </Suspense>
     </div>
   );
}

下面是沙箱链接:https://codesandbox.io/s/hardcore-bouman-egx93

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-10-09 06:11:01

您需要在您的App.js文件中延迟导入您的主页组件(在这里您进行路由),并像这样导入您的产品组件;

App.js

代码语言:javascript
复制
import React, { lazy, Suspense } from 'react'
import { BrowserRouter, Switch, Route } from 'react-router-dom'

const HomePage = lazy(() => import('./pages/home/HomePage'))

class App extends React.Component {

  render() {
    return (
       <BrowserRouter>
          <Switch>
            <Suspense fallback={<h2>Loading...</h2>}>
              <Route exact path='/' component={HomePage}/>
            </Suspense>
          </Switch>
       </BrowserRouter>
      )
  }

}
export default App

延迟加载产品组件,setTimeout to 0,1000只用于调试。

HomePage.js

代码语言:javascript
复制
import React, { lazy, Suspense } from 'react'

const Products = React.lazy(() => {
  return new Promise(resolve => setTimeout(resolve, 1000)).then(
    () => import(".../components/products/Products")
  );
});


export default function HomePage() {
  return (
    <div>
      <Suspense fallback={<h2>Products are loading...</h2>}>
        <Products />
      </Suspense>
    </div>
  );
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58297907

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档