npm 包 @loadable/server 使用教程

@loadable/server 是一个可以让你在服务端使用加载组件的npm包。它的主要作用是让 React 在服务端渲染时可以提高加载速度并使得代码更容易维护。下面我们将会提供详细的介绍和使用指南。

为什么需要 @loadable/server

在进行 React 服务端渲染的时候,我们往往需要使用到 Webpack 进行打包。通常情况下,Webpack 打包后的文件可能非常大,如果在服务端进行同步加载,那么在浏览器渲染页面的时候,我们需要等待所有的 JavaScript 包全部下载完成才行。这会导致非常长的加载时间和较慢的首次渲染。为了解决这个问题,我们需要使用到 @loadable/server

这个包可以使得服务端打包后的文件变得更加轻量化并且只在需要时才将其下载。这样就可以避免大量的 JavaScript 包的加载时间,从而提高页面加载速度并加快首次渲染时间。为了更好地理解 @loadable/server 的使用,下面我们将会给出更加详细的使用指南。

使用指南

首先,我们需要安装 @loadable/server

--- ------- ----------------

然后,在你的服务端代码中引入此包并根据需要进行加载组件的注入。例如,我们有以下一个React组件:

------ ----- ---- -------

------ ------- -------- ------------- -- -
    ------ --------- ---------------
-

在服务端渲染期间,此组件将会被装载。在@loadable/server 中,我们可以使用 loadable 函数进行创建注入组件。首先,让我们在页面中引入 loadable 方法:

------ - --------------- --------------------- - ---- ------------------
------ ----- ---- -------
------ -------------- ---- ------------------
------ ------------- ---- ----------------------------

----- --------- - -------------------------------------------
----- --------- - --- ---------------- --------- --

------ ------- ----- -------- ------------ -- -
    ----- --- - -------------------------------------- ---
    ----- ---- - ----------------------------------
    ----- ---------- - -------------------------
    ----- -------- - -----------------------
    ----- --------- - ------------------------

    ------ -
        -----
        -----------
        ---------
        ----------
    -
-

在上面的代码中,在 serverRender 方法中,我们将 TestComponent 组件装入 jsx 中并注入在 extractor 中。此时,extractor 将会记录包含这个组件的 JavaScript 文件。然后,我们将会使用 ReactDOMServer.renderToString 方法将 jsx 转换成 HTML 字符串,并使用 inject 方法注入我们记录在 extractor 中的 JavaScript 文件。最后,将内容返回作变量使用就可以了。

------ ------------ ---- -----------------

---------------------- ----- ----------- --------- --------- -- -- -
    --------------
        -
        --------- -----
        ------
            ------
                ----- ----------------
                ----- --------------- ---------------------------- ------------------ ------------------ ------------------ ------------------
                --------------- ------ ---------------
                -----------
                ------------
            -------
            ------
                ---- -----------------------
                -------------
            -------
        -------
        -
    -
--

最后,我们需要注意,在打包出来的前端代码中,我们需要使用 loadable-components 作为客户端渲染的注入组件,这样才能正确地使用前面 serverRender 方法获取的注入信息。

------ ----- ---- -------
------ -------- ---- -----------
------ --- ---- -------
------ - -------------- - ---- ------------------

----- ----- - -----------------------------------------
----- --------- - --- ---------------- ----- --

--------------------- ---------- --------------------- --- --------------------------------

完成上面这些步骤后,我们已经成功配置了 @loadable/server

结论

在本文中,我们介绍了 @loadable/server 及其使用。这个包的主要作用是可以让 React 在服务端渲染时可以提高加载速度并使得代码更容易维护。我们详细地介绍了该包的使用方法,希望这个包能够帮助你更好地进行服务端渲染的开发。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/loadable-server


猜你喜欢

  • npm 包 @evocateur/libnpmpublish 使用教程

    前言 在前端开发中,我们常常需要借助 npm 包来快速实现功能。而有时,我们需要自己创建一个 npm 包,供其他开发者使用。在这种情况下,@evocateur/libnpmpublish 可以帮助我们...

    5 年前
  • npm 包 @0x-lerna-fork/collect-uncommitted 使用教程

    前言 在进行前端开发过程中,我们难免会遇到要将一些不同的代码段整合到一起的问题,这时我们就会需要一个工具来帮助我们分析并集合这些代码。本文将介绍一个名为 @0x-lerna-fork/collect-...

    5 年前
  • npm 包 @0x-lerna-fork/run 使用教程

    如果您是前端开发者,肯定会使用一些工具来帮助开发和测试,npm 就是这样一个非常重要的工具。在开发应用程序时,我们需要一个可靠和强大的构建系统,因此选用合适的 npm 包,可以大大提高我们的开发效率。

    5 年前
  • npm 包 @0x-lerna-fork/list 使用教程

    在前端开发中,我们会用到各种各样的 npm 包来帮助我们快速地实现功能以及优化我们的项目。其中一个比较实用的 npm 包是 @0x-lerna-fork/list,这个包提供了一些常用的数组操作以及一...

    5 年前
  • npm 包 @0x-lerna-fork/init 使用教程

    前言 随着前端技术的不断发展,前端工程化的重要性日益凸显,而 Lerna 是一个优秀的针对大型多包管理的工具。而 @0x-lerna-fork/init 是一个基于 Lerna 二次封装的 NPM 包...

    5 年前
  • npm 包 @0x-lerna-fork/import 使用教程

    前言 在现代 Web 开发中,使用第三方的开源工具和库是很常见的一件事情。而 npm 作为一个 Node.js 的包管理器,是我们经常使用的一个工具。其中,@0x-lerna-fork/import ...

    5 年前
  • npm 包 @0x-lerna-fork/exec 使用教程

    介绍 @0x-lerna-fork/exec 是一个 Node.js 模块,用于在 Node.js 中运行子进程的命令并获取它们的输出。这个命令是 Lerna 的分支版本,由 0x 团队维护并改进,是...

    5 年前
  • npm 包 @0x-lerna-fork/diff 使用教程

    简介 @0x-lerna-fork/diff 是一个开源的 npm 包,用于比较两个 JavaScript 对象的差异。它是基于 diff 和 deep-diff 两个包开发的,可以用于前端、后端等各...

    5 年前
  • npm 包 @0x-lerna-fork/clean 使用教程

    在前端开发中,我们常常需要使用各种 npm 包来辅助我们完成任务。其中,一个非常实用的 npm 包是 @0x-lerna-fork/clean。该 npm 包可以帮助我们清理项目中的一些冗余文件,以提...

    5 年前
  • npm 包 @0x-lerna-fork/add 使用教程

    前言 在前端开发中,npm 管理包已经成为非常常见的方式之一。通过使用 npm 包,我们可以方便地引入第三方库,提高开发效率。本文将介绍一个使用 npm 包 @0x-lerna-fork/add 的方...

    5 年前
  • npm包 @0x-lerna-fork/global-options 使用教程

    前言 在前端开发中,我们经常使用npm包来完成一些开发工作。而@0x-lerna-fork/global-options是一个非常实用的npm包,它可以帮助我们更加便捷地处理命令行参数,加快应用程序的...

    5 年前
  • npm 包 infer-owner 使用教程

    在前端开发中,我们经常会使用各类的 npm 包来辅助开发,管理这些包是一件非常重要的事情。infer-owner 是一款可以帮助我们确定一个 npm 包的所有者的工具,今天就来介绍一下它的使用方法。

    5 年前
  • npm 包 @evocateur/npm-registry-fetch 使用教程

    介绍 npm 是 Node.js 生态系统中的包管理工具,方便开发者快速下载、安装、管理和发布 JavaScript 代码等多种类型的包,让开发过程更加便捷和高效。

    5 年前
  • npm 包 @0x-lerna-fork/run-topologically 使用教程

    如果你经常使用 npm,那么你一定知道它极其重要。npm 包是开发前端项目时必不可少的工具之一。本文将介绍一个叫做 @0x-lerna-fork/run-topologically 的 npm 包。

    5 年前
  • npm 包 @0x-lerna-fork/prompt 使用教程

    npm 是 Node.js 的官方包管理器,其丰富的包库可以满足前端开发所需的任何依赖。但是,随着依赖包的增加,越来越多的 Front-End 开发者有了碎片化的开发体验。

    5 年前
  • npm 包 @0x-lerna-fork/prerelease-id-from-version 使用教程

    简介 npm 包 @0x-lerna-fork/prerelease-id-from-version 是一个用于获取预发行版本的 id 的 JavaScript 工具,针对的是语义化版本(SemVer...

    5 年前
  • npm包 @0x-lerna-fork/gitlab-client的使用教程

    简介 在前端开发中,我们经常需要使用GitLab进行代码管理。@0x-lerna-fork/gitlab-client是一个npm包,提供了一系列Api,使得在前端项目中使用GitLab变得更加方便快...

    5 年前
  • npm 包 @0x-lerna-fork/github-client 使用教程

    简介 在前端开发过程中,经常需要操作 Github API 进行代码托管、版本管理等。为了更加便捷地使用 Github API ,@0x-lerna-fork/github-client 库应运而生。

    5 年前
  • npm 包 @0x-lerna-fork/conventional-commits 使用教程

    前言 在前端开发中,我们常常需要管理项目的版本号以及版本控制提交信息。常见的做法是使用 语义化版本控制规范,其中 conventional commits 是一种比较流行的规范,可以自动生成 chan...

    5 年前
  • npm 包 @0x-lerna-fork/filter-packages 使用教程

    介绍 在前端开发中,我们常常需要使用很多 npm 包来完成我们的工作。然而,有时候我们需要对这些包进行一定的筛选和过滤,以达到更好的效果。而 npm 包 @0x-lerna-fork/filter-p...

    5 年前

相关推荐

    暂无文章