Vue服务器渲染Nuxt学习笔记

关于SSR的文章网上很多,一开始看得我云里雾里。然后去Vue.js 服务器渲染指南nuxt官网看了看,发现文章大多都是搬运官网的内容,真正讲的清晰明了的很少。所以想写篇文章学习下SSR,希望能够帮助大家快速理解Vue SSR。

什么是SSR?

SSR,即服务器渲染,就是在服务器端将对Vue页面进行渲染生成html文件,将html页面传给浏览器。 优点:

  1. SEO 不同于SPA的HTML只有一个无实际内容的HTML和一个app.js,SSR生成的HTML是有内容的,这让搜索引擎能够索引到页面内容
  2. 更快内容到达时间 传统的SPA应用是将bundle.js从服务器获取,然后在客户端解析并挂载到dom。而SSR直接将HTML字符串传递给浏览器。大大加快了首屏加载时间。

可以从下面两张图来看,第一张图是SSR生成的HTML页面,第二种是传统SPA生成的HTML页面

Nuxt.js

我看了官方 SSR 的介绍,也看了 Nuxt.js 的文档。本质上来说 SSR 是node后端的操作行为,作为只想好好写前端代码的我,不想太折腾。而 Nuxt.js 非常完美地整合了 SSR 的功能。让我们可以开箱即用~官方也推荐使用 Nuxt.js 来搭建 SSR 项目。

好处

我觉得 Nuxt.js 相比自己写 SSR 有几点好处。

  1. 无需配置Webpack:我一开始还在找Webpack配置呢,看了文档知道nuxt都帮我们封装好了。如需修改Webpack配置只需修改nuxt.config.js 文件
  2. 无需node知识:只要你会写vue前端,你就可以写出SSR。无需知道SSR和node、express的配置方法(不过现在的前端多少都会点node知识~)。
  3. 整合了vue全家桶,直接可用。方便程度不亚于 vue-cli:安装Nuxt——写组件——编译并启动服务———看效果。就这么简单。
  4. 配置简单,文档友好:认真看下 Nuxt.js 文档就会发现涵盖的内容并不多,而功能很全,非常适合入手。

安装

安装方法在此。很简单,生成模板,然后npm安装依赖,最后再运行。

简单搬运下步骤吧。

rush:plain;"> // vue-cli 创建nuxt模板项目 $ vue init nuxt-community/starter-template // 安装依赖项 $ cd $ npm install // 编译并启动服务 $ npm run dev // 打开 http://localhost:3000

安装遇到的问题:

由于 Nuxt.js 中使用了 async...await 语法,而低版本的 node 不支持这个语法,所以必须升级 node 到 7.0 版本之上~

然后建议不要使用cnpm,我用cnpm安装运行老报错,感觉有坑。

目录结构

Nuxt.js 花了很大的篇幅讲它的目录结构,其实了解了目录结构就了解了 Nuxt.js 的大概。Nuxt.js 帮我们配置好了所有东西,我们只需要按照它的要求在相应目录下创建文件代码即可。

  1. assets 需要编译的资源文件,如 JavaScript、SASS、LESS 等。
  2. static 不需要编译的静态资源文件,如图片资源。
  3. components 顾名思义,存放 *.vue 组件的地方。常规 vue 组件写法。
  4. layouts 布局目录,设置布局的地方,其中 标签是我们写的页面内容。可用作添加导航栏、底部栏等截面。
  5. middleware 中间件目录,所谓中间件,就是在页面页面跳转中执行的函数方法。如页面跳转时验证用户信息操作。
  6. pages 页面目录。重点来了~这就是我们存放展示页面的地方。该目录下的文件会转换成相应的路由路径供浏览器访问。另外呢,该目录下的 *.vue 页面文件中 Nuxt.js 提供了一些特殊的方法用于处理服务器渲染中的事件。具体关于路由和特殊方法列举在下面了。
    1. pages 路由
    2. 页面组件的简单介绍,具体特殊配置项的用法请查阅API
  7. plugins 插件目录,像 mint-ui 这种第三方插件就放在这里啦~具体用法看这里
  8. store vuex 状态管理器目录,如果该目录是空的, Nuxt.js 将不启用 vuex。当我们在该文件夹下创建 index.js 文件后即可使用 vuex 状态管理器。用法在此
  9. nuxt.config.js文件是 Nuxt.js 的唯一配置项,之前提过 Nuxt.js 将 Webpack 等一众配置都封装好了,所以如果需要特殊配置,只需要修改文件来覆盖认配置即可。具体配置参数请查阅API
  10. package.json 不解释……

Demo演示

好消息,VueStudyDemos又更新啦!欢迎Star~本文Demo已收入到VueStudyDemos中。

下面我们来简单实现下各文件夹所提到的功能

资源加载

我在 assets 文件夹下添加了 font-awesome 字体库,在 static 文件夹中放了张 Vue 的 logo 图片。然后对资源进行调用

rush:xhtml;">