Nuxt入门

1. 什么是 Nuxt.js

Nuxt.js 是一个基于 Vue.js 的通用应用框架,它帮助我们轻松构建服务器渲染的 Vue.js 应用。最常用的就是用来作SSR(服务器端渲染).Vue.js是开发SPA(单页应用)的,Nuxt.js这个框架,用Vue开发多页应用,并在服务端完成渲染,可以直接用命令把我们制作的vue项目生成为静态html。

主要的原因时SPA(单页应用)不利于搜索引擎的SEO操作,Nuxt.js适合作新闻、博客、电影、咨询这样的需要搜索引擎提供流量的项目。
 

1.1 什么是SSR?

在认识SSR之前,首先对CSR与SSR之间做个对比。

首先看一下传统的web开发,传统的web开发是,客户端向服务端发送请求,服务端查询数据库,拼接HTML字符串(模板),通过一系列的数据处理之后,把整理好的HTML返回给客户端,浏览器相当于打开了一个页面。这种比如我们经常听说过的jsp,PHP,aspx也就是传统的MVC的开发。

SPA应用,到了Vue、React,单页面应用优秀的用户体验,逐渐成为了主流,页面整体式javaScript渲染出来的,称之为客户端渲染CSR。SPA渲染过程。由客户端访问URL发送请求到服务端,返回HTML结构(但是SPA的返回的HTML结构是非常的小的,只有一个基本的结构,如第一段代码所示)。客户端接收到返回结果之后,在客户端开始渲染HTML,渲染时执行对应javaScript,最后渲染template,渲染完成之后,再次向服务端发送数据请求,注意这里时数据请求,服务端返回json格式数据。客户端接收数据,然后完成最终渲染。(请求两次,百度搜索引擎不能抓取SPA页面的数据)

SPA虽然给服务器减轻了压力,但是也是有缺点的:

首屏渲染时间比较长:必须等待JavaScript加载完毕,并且执行完毕,才能渲染出首屏。
SEO不友好:爬虫只能拿到一个div元素,认为页面是空的,不利于SEO。
为了解决如上两个问题,出现了SSR解决方案,后端渲染出首屏的DOM结构返回,前端拿到内容带上首屏,后续的页面操作,再用单页面路由和渲染,称之为服务端渲染(SSR)。

SSR渲染流程是这样的,客户端发送URL请求到服务端,服务端读取对应的url的模板信息,在服务端做出html和数据的渲染,渲染完成之后返回html结构,客户端这时拿到的之后首屏页面的html结构。所以用户在浏览首屏的时候速度会很快,因为客户端不需要再次发送ajax请求。并不是做了SSR我们的页面就不属于SPA应用了,它仍然是一个独立的spa应用。

SSR是处于CSR与SPA应用之间的一个折中的方案,在渲染首屏的时候在服务端做出了渲染,注意仅仅是首屏,其他页面还是需要在客户端渲染的,在服务端接收到请求之后并且渲染出首屏页面,会携带着剩余的路由信息预留给客户端去渲染其他路由的页面。

1.2 Nuxt.js 的特性

Nuxt.js 提供了许多有用的特性,包括:

  • 自动生成的路由配置
  • 服务器渲染(SSR)
  • 异步数据加载和错误处理
  • 支持静态站点生成
  • 内置的模块化架构
  • 自动生成的样式和模块处理
  • 丰富的插件生态系统

2. 安装和配置

2.1 安装 Nuxt.js

使用 npm 或 yarn,我们可以很容易地安装 Nuxt.js。

# 使用 npm
$ npm install nuxt

# 使用 yarn
$ yarn add nuxt

2.2 创建 Nuxt.js 项目

通过运行 Nuxt.js 的命令行工具,我们可以快速创建一个新的 Nuxt.js 项目。

$ npx create-nuxt-app my-project

2.3 配置 Nuxt.js

Nuxt.js 的配置文件 nuxt.config.js 允许我们自定义许多选项,例如页面路由、构建配置和插件配置等。我们可以根据项目的需求进行相应的配置。

3. 页面和路由

3.1 页面目录

在 Nuxt.js 中,页面是位于 pages 目录下的 Vue 组件,每个组件将生成一个对应的路由。

3.2 路由配置

Nuxt.js 自动生成路由配置的方式非常简单,我们只需要在 nuxt.config.js 中设置 router: { ... } 选项即可。我们也可以在页面组件中使用 <nuxt-link> 来实现导航。

4. 数据获取

4.1 异步数据加载

Nuxt.js 提供了 asyncData 方法,它可以在路由组件渲染之前异步加载数据,并将数据注入到组件中。我们可以使用该方法获取远程 API 的数据或通过其他方式加载数据。

4.2 错误处理

Nuxt.js 具有内置的错误处理机制,可以轻松地处理数据加载过程中的错误。我们可以使用 fetch 方法来获取数据,并且 Nuxt.js 会自动处理各种错误情况。

5. 部署和发布

5.1 打包和构建

要打包和构建 Nuxt.js 应用,我们可以使用 nuxt build 命令。Nuxt.js 会生成一个优化过的生产环境应用,并将其输出到 .nuxt 目录中。

5.2 部署到服务器

在将 Nuxt.js 应用部署到服务器时,我们可以使用 nuxt start 命令来启动应用,或者通过将应用作为 Node.js 服务运行。

5.3 静态站点生成

Nuxt.js 还提供了生成静态站点的功能,我们只需要运行 nuxt generate 命令,Nuxt.js 会自动生成静态 HTML 文件并输出到 dist 目录中。

结论

Nuxt.js 简化了 Vue.js 应用的开发流程,提供了许多开箱即用的功能和最佳实践。不论是构建服务器渲染的应用,还是生成静态站点,Nuxt.js 都是一个强大而灵活的选择。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值