Nuxt简介和流程图

相关阅览

官网 Vue.js服务器端渲染指南(英文)

官网 静态化 (预渲染)

官网 nuxtServerInit 方法

官网 API: middleware 属性

官网 API: asyncData 方法

官网 API: validate 方法

官网 API: fetch 方法

Nuxt.js生命周期详解

Nuxt.js简介

Nuxt.js 是一个基于 Vue.js 的轻量级应用框架,可用来创建服务端渲染 (SSR) 应用,也可充当静态站点引擎生成静态站点应用,具有优雅的代码结构分层和热加载等特性。

服务端渲染(SSR)

利用 SSR(Server-Side Rendering),Node.js 服务器 将基于 Vue 的组件渲染成 HTML 并传输到客户端,而不是纯 javascript。 与传统的 Vue SPA 相比,使用 SSR 将带来巨大的 SEO(搜索引擎优化) 提升、更好的用户体验和更多的机会。

生成静态站点

Nuxt.js 支持基于 Vue 应用程序生成静态站点。这是“两全其美”的, 因为你不要服务器,但是仍能获得 SEO 的好处,这是因为 Nuxt 将预先渲染所有页面,并且包括必要的 HTML。

支持 Vue.js 应用的静态化算是 Nuxt.js 的一个创新点,通过 nuxt generate 命令实现。该命令依据应用的路由配置将每一个路由静态化成为对应的 HTML 文件。

静态化可以让你在任何一个静态站点服务商托管你的Web应用。

我们进一步考虑下电商应用的场景,利用 nuxt generate,是不是可以将应用静态化后部署在 CDN 服务器,每当一个商品的库存发生变化时,就重新静态化下,更新下商品的库存。但是如果用户访问的时候恰巧更新了呢?我们可以通过调用电商的 API ,保证用户访问的是最新的数据。这样相对于传统的电商应用来说,这种静态化的方案可以大大节省服务器的资源。

NUxt.js流程图

nuxtServerInit服务器初始化

在Nuxt.js中只有page里的组件有fetch和asyncData方法,所以当我们使用layout布局页面时如果组件需要请求数据,就无法渲染了,解决方法是在nuxtServerInit方法里初始化组件内的数据。

如果你使用_状态树模块化_的模式,只有主模块(即 store/index.js)适用设置该方法(其他模块设置了也不会被调用)。

实际上nuxtServerInit用于在服务端操作 store 的,实质上就是一个 Action。

middleware中间件运行

这个函数可以使用在nuxt.config.js、layouts、pages中使用,会在页面初始化之前被调用。

示例 官网 中间件

validate()校验参数

可以让你在动态路由对应的页面组件中配置一个校验方法用于校验动态路由参数的有效性。比如对路由参数验证失败,判定为一个非法参数后,跳转到404页面或者一个提醒页面。

示例 官网 validate

asyncData()和fetch()

asyncData()

asyncData方法会在组件(限于页面组件)每次加载之前被调用。它可以在服务端或路由更新之前被调用。在这个方法被调用的时候,第一个参数被设定为当前页面的上下文对象,你可以利用 asyncData方法来获取数据并返回给当前组件。

通俗解释:asyncData其实是运行在page页面加载前的一个方法,这个方法只能在页面组件中使用,这个方法的作用很多,比如:ajax数据请求、操作state数据、页面重定向等等。

这里涉及到一点,单纯用vue的时候,可以用在created生命周期阶段进行ajax数据的请求,只是这样的话查看源代码的时候就看不到这些数据。也就实现了服务端渲染

fetch()

asyncData既可以充应用的状态树(store)数据,也可以设置组件的数据。

fetch 方法用于在渲染页面前填充应用的状态树(store)数据, 与 asyncData 方法类似,不同的是它不会设置组件的数据。

render

渲染页面

流程图图示

下图阐述了 Nuxt.js 应用一个完整的服务器请求到渲染(或用户通过 切换路由渲染页面)的流程:

posted @ 2020-06-03 10:38  浮华而已-  阅读(1651)  评论(1编辑  收藏  举报