《家庭财务宝典》

一文搞定nuxt.js搭建到部署(ssr和静态部署)

40次阅读

共计 4872 个字符,预计需要花费 13 分钟才能阅读完成。

一文搞定nuxt.js搭建到部署(ssr和静态部署)插图

一、Nuxt 简介

uxt 是一个更高级别的 Node.js web 开发框架,用于创建 Vue 应用,可在两种不同模式下开发和部署:通用 (SSR) 或单页应用(SPA)。此外,您可以在 Nuxt 中将 SSR 和 SPA 部署为静态生成的应用。即使您可以选择 SPA 模式,Nuxt 的全部功能仍在于其通用模式或用于构建通用应用的服务器端渲染(SSR)。通用应用用于描述可以在客户端和服务器端执行的 JavaScript 代码。

为什么要使用 Nuxt?

Nuxt 等框架的存在是因为传统 SPA 的缺点和多页应用(MPAs 的服务器端呈现)。我们可以将 Nuxt 视为服务器端渲染 MPA 和传统 SPA 的混合体。因此,它被称为“普遍的”或“同构的”。因此,能够进行服务器端渲染是 Nuxt 的定义特性。

二、什么是 SSR?

SSR 是服务端渲染:在后台将 vue 实例渲染为 HTML 字符串直接返回,在前端激活为交互程序。

实现原理:

  1. 客户端发送请求给服务器
  2. 服务器查询数据库,使用视图、模板引擎等拼接成 html 字符串,返回给客户端
  3. 客户端渲染 html

优点:

  1. 网页内容在服务器端渲染完成,一次性传输到浏览器,所以首屏加载速度非常快
  2. 有利于 SEO,因为服务器返回的是一个完整的 html,在浏览器可以看到完整的 dom,对于爬虫、百度搜索等引擎就比较友好

缺点:

在后续跳转其它链接时,整个页面还要重复这样的操作,不断地请求响应、请求响应,相对来说,消耗的带宽资源、后续请求的时间就多了

单页应用 SPA:

单页应用其优秀的用户体验,使其逐渐成为主流,页面内容由 js 渲染出来,这种方式称为客户端渲染。它的过程是:

  1. 客户端发送请求给服务器
  2. 服务器返回 html,但这时的 html 只有基本的结构(比如 vue 中,只有 app 这个 div 结构),没有其他具体的 dom 结构
  3. 客户端渲染 html,渲染执行 js(比如 vuejs),渲染模板 template,这时候会再向服务器发送请求,请求具体的数据
  4. 服务器查询数据库,返回对应的数据
  5. 客户端渲染显示

缺点:

  1. 网速很慢的时候,它的首屏等待时间较长
  2. SEO 不友好,暴露给搜索引擎只有最基本的 html 结构
(比如:<div id="app"></div>)

如何搭建你的 nuxt 应用

1. yarn create nuxt-app < 项目名>

执行完命令后会初始化一个 nuxj.js 的项目

一文搞定nuxt.js搭建到部署(ssr和静态部署)插图1
  • asset: 资源目录  assets  用于组织未编译的静态资源如  LESS、SASS  或  JavaScript, 图片和 css 等静态文件都要存放的 asset 目录下,否则打包之后会出现找不到资源的情况
  • components:组件目录,用来存放自定义组件的目录,跟一般的 vue 组件没有区别
  • layouts:布局目录,可以在里面写默认布局文件,注意默认布局文件的名称必须是 default.vue,并且 layouts 文件夹的目录没有必要的情况下不要更改。注意:default.vue 默认是不存在的,如果要改布局需要自己添加
一文搞定nuxt.js搭建到部署(ssr和静态部署)插图2

middleware  目录用于存放应用的中间件。中间件可以理解为经过不同的路由时都会执行的函数,这里我没有使用就不再赘述可以自己看文档 https://www.nuxtjs.cn/guide/routing#%E4%B8%AD%E9%97%B4%E4%BB%B6

  • pages:页面目录 pages 用于组织应用的路由及视图。Nuxt.js 框架读取该目录下所有的 .vue 文件并自动生成对应的路由配置。若无额外配置,该目录不能被重命名。值得注意的是:nuxt 中是不需要你手写路由的,直接在 pages 里面增加文件夹即可。例如要增加一个路由为 news 的页面,只需要在 pages 文件夹里面新建一个 news 文件夹里面新建一个 index.vue 文件即可。当然你也可以看到对应的 router.js 文件
一文搞定nuxt.js搭建到部署(ssr和静态部署)插图3

不同页面之间的跳转使用 nuxt-link 组件即可,传递对应的 name 即可,也可以传递参数,用 params 属性传递即可

<nuxt-link :to="{name:'products', params: { keyword: item.name}}">{{item.name}}</nuxt-link>
一文搞定nuxt.js搭建到部署(ssr和静态部署)插图4

plugins:插件目录  plugins  用于组织那些需要在   根 vue.js 应用   实例化之前需要运行的 Javascript 插件。

注意:在 nuxt 中使用插件和在一般的 vue 中是有很大差别的

一般只需要 npm 安装对应的包,然后在 main.js 中引入和使用即可

但是在 nuxt 中你需要在 plugins 文件夹中定义对应的 js 来引入插件,然后再 nuxt,config.js 中来配置才能使用

例如我要使用 element-ui

首先要 npm 安装

然后需要再 plugins 文件夹里面顶一个 JS 来进行引入和使用,JS 的名字随便起

一文搞定nuxt.js搭建到部署(ssr和静态部署)插图5

然后在 nuxt.config.js 中引入这个 js,

一文搞定nuxt.js搭建到部署(ssr和静态部署)插图6

对于 element 这种需要引入 css 的插件还需要,在 nuxt.config.js 里面的 css 配置项里面引入对应的样式库

一文搞定nuxt.js搭建到部署(ssr和静态部署)插图7

static: 静态文件目录  static  用于存放应用的静态文件,此类文件不会被 Nuxt.js 调用 Webpack 进行构建编译处理。服务器启动的时候,该目录下的文件会映射至应用的根路径  /  下。

store  目录用于组织应用的  Vuex 状态树   文件。Nuxt.js 框架集成了  Vuex 状态树   的相关功能配置,在  store  目录下创建一个  index.js  文件可激活这些配置。

一文搞定nuxt.js搭建到部署(ssr和静态部署)插图8

这里和一般的 vue 项目中使用 vuex 没什么区别

nuxt.config.js 文件:nuxt.config.js  文件用于组织 Nuxt.js 应用的个性化配置,以便覆盖默认配置。

这个文件很关键,项目打什么类型的包,以什么方式运行以及一些三方插件库都需要在这里面配置,包括一些 SEO 优化还有 html 的头部都是在这里配置。

这里我之说几个关键和常用的配置选项,其他的有兴趣可以去看官网。

ssr 配置项,可以设置 true 和 false,j 是否启动 ssr 渲染,ssr:true 是默认值

target:static/server, 采用静态渲染还是服务端渲染

一般情况下 ssr:true 与 target:server 一起使用,然后执行 npm run build 即可构建一个 ssr 的包,发布到服务器即可完成 ssr。

如果要打一个 spa 的包只需要设置 ssr:false 即可,target 配置项不需要设置

如果要打一个静态部署的包你需要设置 ssr:true,target:static

这些主要是打包的配置

除了这些还有 css 配置项,是用来引入全局样式的,还有 plugin 配置项是用来注册插件的。这些就是主要的配置项

三、使用 flexable.js 和 postcss-pxtorem 插件来进行 PC 端的适配

这里主要是做一个官网的项目,所以要针对不通的 PC 端屏幕进行适配。

我采用的是 flexable.js 和 postcss-pxtorem。我一开始用的是 postcss-px2rem 后来发现和 nuxt 引入公共 css 的时候发生了冲突所以改用了 postcss-pxtorem。

先 npm 安装包然后定义一个 JS 在 plugins 文件夹里面引入

一文搞定nuxt.js搭建到部署(ssr和静态部署)插图9

再在 nuxt.config.js 里面配置 plgins 配置项

一文搞定nuxt.js搭建到部署(ssr和静态部署)插图10

到这里就完成了对 flexable.js 的引入和使用。

但是因为 flexable.js 主要是适配移动端的所以我们要对其源码进行更改

node_modules\lib-flexible\flexible.js 文件中

refreshRem 方法

一文搞定nuxt.js搭建到部署(ssr和静态部署)插图11

下一步就是引入 postcss-pxtorem。

一文搞定nuxt.js搭建到部署(ssr和静态部署)插图12
build: {
    postcss: {
      plugins: {
        "postcss-pxtorem": {
          rootValue: 192,
          propList: ["*"],
          minPixelValue: 2
        }
      }
    },
  },

这样就完成了适配

四、如何将开发好的 nuxt 项目部署到服务器上?

(1)ssr 渲染:

首先来介绍如何进行 SSR 渲染:开发完成项目之后,将 nuxt.confing.js 里面的 SSR 配置项设为 false, 然后将 target 配置项设置为:server

运行 npm run build 进行打包

打包后会生成.nuxt 文件夹

一文搞定nuxt.js搭建到部署(ssr和静态部署)插图13
一文搞定nuxt.js搭建到部署(ssr和静态部署)插图14

这时候可以先本地执行 npm start 看一下是否正常启动。

启动后看一下网路请求里面的 document 是否是有内容的 html 的页面

一文搞定nuxt.js搭建到部署(ssr和静态部署)插图15

如果是就代表 SSR 本地启动成功了。

这时候咱们需要把它部署到服务器上去。

第一步是连接到你的服务器,这里我用的是 mobaXterm

一文搞定nuxt.js搭建到部署(ssr和静态部署)插图16

进入服务器之后随便找一个文件夹新建一个文件夹将咱们 nuxt 项目中的相关文件丢进去

需要丢的有

一文搞定nuxt.js搭建到部署(ssr和静态部署)插图17

这里注意最好保证本地 node 版本和服务器上的一致。

当然你也可以除了 node_nodules 全部丢进去。

然后在服务器是执行 npm start 即可,当然你得进入项目所在的文件夹

一文搞定nuxt.js搭建到部署(ssr和静态部署)插图18

可以看到在服务器上项目已经跑起来了,这时候你点击 listening 后面得连接时进不去得因为那是私网的域名。

这时候你需要在 nginx 上面进行反向代理

一文搞定nuxt.js搭建到部署(ssr和静态部署)插图19

这时候在你的服务器上面找到 nginx/conf.d 文件夹,在下面新建一个.conf 文件进行代理配置

当然你需要把你监听的 9001 端口在安全组中打开

一文搞定nuxt.js搭建到部署(ssr和静态部署)插图20

然后就可以通过 http: 域名: 端口访问了。

(2)SPA 方式部署:将项目部署为普通的 spa 应用的步骤:

1. 设置 nuxt.config.js 文件中的 ssr 配置项为 false

2. 执行 npm run generate 打包,这里可能会报错 xxx is not in cwd, 这时你需要找到 node_modules@nuxt\cli\dist\cli-generate.js 文件修改以下代码

export async function snapshot ({globbyOptions, ignore, rootDir}) {const snapshot = {}
 
  const files = await globby('**/*.*', {
    ...globbyOptions,
    ignore,
    cwd: rootDir,
    absolute: true
  })

把上面的 cwd:rootDir 改为  cwd : upath . normalize (rootDir) 就好了。

const  files  =  await  globby__default [ 'default' ] ( '**/*.*' ,  { 
    ... globbyOptions , 
    ignore , 
    cwd : upath . normalize (rootDir) , 
    absolute : true 
  } ) ;

执行完命令会在根目录生成 dist 文件

一文搞定nuxt.js搭建到部署(ssr和静态部署)插图21

同样在服务器任意位置新建一个目录,将 dist 文件夹丢入即可

一文搞定nuxt.js搭建到部署(ssr和静态部署)插图22

然后就是进行 nginx 的配置

可以在已有的.cof 文件中新加 server,也可以新建一个.cof 文件写 server

server {
      listen 4567;// 监听的端口
      server_name 21.23.18.12;// 你的域名或者 Ip 地址
      location / {
        root /home/nxutsever/dist;  // 重定向的目录,就是你的 dist 文件夹所在的位置
        try_files  $uri $uri/ dist/index.html;// 搜索的文件,就是 dist 下面的 index.html
        index  index.html index.htm;//index 配置项
      }
    }

配置完成之后重启 nginx, 在浏览器输入 http://ip+: 端口号即可访问。

访问之后可以打开网络请求检查一下 document 文件返回的是什么

一文搞定nuxt.js搭建到部署(ssr和静态部署)插图23

发现只有一个空壳子,说明 SPA 部署成功了

至此 Nuxt 的 ssr 部署和 spa 部署就结束了。如果本文对各位有帮助,欢迎点赞!

你的工作,由 AI 赋能!🔥

还在为文案、脚本卡壳、做视频、写代码、设计图片灵感枯竭而烦恼吗?🤯

板板 AI,你的工作好帮手!

一键生成    各种文案、脚本、图片、视频、代码、报告,轻松应对各种工作 / 营销需求!

现在注册体验,即可获得:

  • 🎁 30 积分基础模型余额
  • 🎁 3 积分高级模型余额
  • 🎁 3 积分绘画余额

还不快来试试?

点击链接,开启你的 AI 创作之旅!>>>https://www.banbanai.cn

板板 AI,让你的工作效果发挥无限可能! 🚀

正文完
关注板板AI免费获得移动AI助手
post-qrcode
 
天天
版权声明:本站原创文章,由 天天 2024-11-18发表,共计4872字。
转载说明:

本文由 天天资讯网 整理发布,转载请注明出处.
版权声明:部分文章内容或图片来源于网络,我们尊重作者的知识产权。如有侵犯,请联系我们在第一时间删除。

文字广告位10/月 文字广告位10/月 文字广告位10/月 文字广告位10/月 文字广告位10/月
文字广告位10/月 文字广告位10/月 文字广告位10/月 文字广告位10/月 文字广告位10/月
文字广告位10/月 文字广告位10/月 文字广告位10/月 文字广告位10/月 文字广告位10/月
文字广告位10/月 文字广告位10/月 文字广告位10/月 文字广告位10/月 文字广告位10/月
文字广告位10/月 文字广告位10/月 文字广告位10/月 文字广告位10/月 文字广告位10/月

温馨提示:请在上面搜索| 查找更多免费资源,如需广告位请联系站长QQ 48704478

《家庭财务宝典》