最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • [重学 Next.js] — 你应该知道的 Next.js 高级用法 10 点 (上)

    正文概述 掘金(前端周同学)   2021-08-25   769

    这是我参与8月更文挑战的第4天,活动详情查看:8月更文挑战

    前言

    之前出过很多 Next.js 系列的文章,也因此收获了很多朋友,不敢说 Next.js 用的有多好,但是个人对于 Next.js 应该绝对算得上是真爱了。之前因为个人原因,Next.js 更多的是停留在用的阶段,并且因为工作原因,还有大概一年半的时间没用过 Next.js 写项目,最近随着经验和年限增加,回过头来看感觉有些意难平,希望重新拾起对 Next.js 的热情,因此准备了一个系列 —— 《重学 Next.js》,希望从更深的角度去重温这位老朋友。文章可能会分为几个方向,看感觉随机写:

    • 1 - 实践系列。比如高级用法、最佳实践以及新特性的使用等等。

    • 2 - 源码系列。既然要更深入,那么源码就躲不过去,还是要啃的。

    • 3 - 翻译系列。翻译国外很多大牛的文章,其实 Next.js 的受众,还是国外居多。如果是翻译,会先征得作者的同意

    废话少说,开始第一篇文章,第一篇文章就简单的溜溜缝,在一年半之前最后使用 Next.js 更新的版本还是 Version 8,看一下官网他已经更新到了 Version 11,真的是非常感慨啊。有很多新特性都不清楚,所以从官网上找了一篇文章或者说文档更为准确,进行了一下翻译以及简单实用,理解自身的理解并且搭配 Demo,给大家说一下使用 Next.js 你应该掌握的 10 点高级用法。

    I - Next.js Redirects —— 重定向

    重要参数

    • source :传入的请求路径,也就是原路径
    • destination 目标路径,也就是重定向到目标路径
    • permanent 是否是永久重定向,如果为 true 就是永久重定向也就是 302,如果为 false 就是暂时的,也就是 301。

    示例代码

    // next.config.js
    
    module.exports = {
      async redirects() {
        return [
          {
            source: '/home',
            destination: '/',
            permanent: true,
          },
        ]
      },
    }
    

    上述代码,可以将 /home 路径重定向到 /,通过一个实际例子来看看效果。

    [重学 Next.js]  — 你应该知道的 Next.js 高级用法 10 点 (上)

    熟悉 Next.js 的同学应该都知道,如上图所示,pages 文件夹就会被自动解析注册路由,那么现在我们整个系统里来说,其实只存在一个跟路径 /,并没有编写 /home 路由,正常来说如果没有使用 redirects 应该是 404,而现在我们是用了 redirects,看看是什么效果。

    [重学 Next.js]  — 你应该知道的 Next.js 高级用法 10 点 (上)

    可以看到,没有出现 404,而是输入 /home 直接帮我们进行了重定向,除此之外,还能进行多级路径匹配,功能很强大,感兴趣的可以自己去实际使用看看效果。

    II - Next.js Rewrites —— 重写

    介绍完 Redirects 我们紧接着就来介绍一个官方也承认的和 Redirects 非常像的一个兄弟功能 —— Rewrites。

    示例代码

     <Link href="/list">
        <a className={styles.card}>
          <h2>List &rarr;</h2>
          <p>List 列表页.</p>
        </a>
     </Link>
    
    <Link href="/rewrites">
        <a className={styles.card}>
          <h2>Rewrites &rarr;</h2>
          <p>路由 /rewrites.</p>
        </a>
    </Link>
    
    // next.config.js
    
    async rewrites() {
        return [
          {
            source: '/rewrites',
            destination: '/list',
          }
        ]
      },
    

    首先,明确的是我们的路由系统没有 /rewrites 这个路由,有的是 /list,通过 Rewrites 把 /rewrites 重写成了 /list 对应的页面,来看一下效果:

    [重学 Next.js]  — 你应该知道的 Next.js 高级用法 10 点 (上)

    可以非常清楚地看到,我们访问一个路由系统里不存在的页面 /rewrites,原本应该是 404,但是因为我们对它进行了重写,所以最后呈现出来的是 /list 路由对应的页面。

    Rewrites 和 Redirects 有什么区别呢?

    那么,看起来 Rewrites 和 Redirects 这俩兄弟功能做的事差不多啊,那么为啥还要做两个功能呢?这俩到底有啥区别呢?别着急,下面就来简单分析一下:

    • 表现形式不同

    仔细看上面两个 Demo 截图的效果,Redirects 和 Rewrites 从表现形式上来看有两点不同。

    1 - 第一点:路径呈现效果不同,Redirects 呈现的是 destination 也就是目标路径,而 Rewrites 呈现的是 source 也就是元路径。

    2 - 第二点:页面实际效果不同,Redirects 呈现的是一个类似刷新页面或者说 <a /> 标签的一个效果,看起来像脱离了站点,而 Rewrites 呈现的就是一个站内前端路由的一个效果,没有刷新跳转的过程。

    • 编译时调用时机不同

    Redirects 是在检查整个文件系统 pagespublic 之前调用。

    Rewrites 是在检查整个文件系统 pagespublic 之后且在生成动态路由之前,进行调用。

    上面这两句话可能看不太懂,没关系,我们还是通过代码来看看:

    // next.config.js
    
     async redirects() {
       return [
         {
           source: '/home',
           destination: '/',
           permanent: true,
         },
         {
           source: '/rewrites',
           destination: '/list',
           permanent: true,
         }
       ]
     },
     async rewrites() {
       return [
         {
           source: '/rewrites',
           destination: '/list',
         }
       ]
     },
    

    可以看到,我们在 Redirects 和 Rewrites 都做了差不多的处理,在 Redirects 里我们把 /rewrites 重定向到 /list,在 Rewrites 里我们把 /rewrites 重写成 /list,那么通过最后页面的实际展现效果,我们也能知道二者的执行顺序,如果最后页面是 /list,那么就说明 Redirects 是后调用的,如果最后页面是 /rewrites 那么说明 Rewrites 是后调用的。

    [重学 Next.js]  — 你应该知道的 Next.js 高级用法 10 点 (上)

    最后的效果和上面总结的一样,说明 Redirects 是先被调用的,而 rewrites 是后被调用的,所以总结来说,虽然二者有很多相似的地方,但是存在着本质上的不同,所以还是两个 API,需要根据场景去使用。

    III - Next.js Preview Mode —— 预览模式

    预览模式的应用场景在平时开发过程中基本没怎么使用过,所以这里不做过多介绍,如果你恰好有类似的场景,比如 CMS,那么可以去官网查阅相关内容。对的没错就是这么随意,个人感觉应用场景不足,也没怎么使用过,介绍下来也不过是浪费时间,还不如去官网。

    IV - Hooking into Build Process —— 构建过程钩子

    Next.js 是一个约定大于配置的框架,大部分的通用的基础功能 Next.js 框架本身已经帮开发者预置好了一套便捷可用方案,与此同时,如果你还是需要在构建时做一些额外的工作的话,那么 Next.js 也是支持的,它为开发者开了一个口子 —— next.config.js,在里面我们可以做诸如:Webpack 配置、创建站点地图等。关于配置的详细信息,可以在此查看 -> next.config.js 文档。

    V - Next.js with Preact

    众所周知,Next.js 是基于 React.js 的框架,但是其实 React.js 框架本身并不算轻量,如果你并不去及时的使用 React.js 的高级功能,只是使用 React.js 开发模式以及语法,那么 Next.js 支持将 React.js 切换成 Preact.js 来减小体积。

    示例代码

     "dependencies": {
        "next": "11.1.0",
        "preact": "^10.5.14",
        "preact-render-to-string": "^5.1.19",
        "react": "17.0.2",
        "react-dom": "17.0.2"
     },
    
    // next.config.js
    
     webpack: (config, { dev }) => {
        // Replace React with Preact only in client production build
        if (!dev) {
          Object.assign(config.resolve.alias, {
            react: 'preact/compat',
            'react-dom/test-utils': 'preact/test-utils',
            'react-dom': 'preact/compat'
          });
        }
    
        return config;
     }
    

    通过非常简单的配置,就可以完成 Preact 无缝替换 React,并且我们只需要在生产环境开启替换,所以也避免了开发过程就需要我们去熟悉掌握 Preact 相关知识这一问题,接着来直观对比一下二者的打包体积:

    • React

    [重学 Next.js]  — 你应该知道的 Next.js 高级用法 10 点 (上)

    • Preact

    [重学 Next.js]  — 你应该知道的 Next.js 高级用法 10 点 (上)

    相同项目,核心 js 文件使用 React.js 比 Preact.js 单文件普遍大上 30 Kb 左右,当路由系统多了以后,几十个几百个页面,这个体积上的缩小还是十分可观的。

    总结

    由于十点一起说完内容过多怕大家不容易消化,所以剩下的五点在下一篇文章给大家介绍,剩下的五点更加的有趣,敬请期待~

    项目地址


    起源地下载网 » [重学 Next.js] — 你应该知道的 Next.js 高级用法 10 点 (上)

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元