体验Vue3的SSR框架 - Nuxt3

news2024/9/25 11:19:33

SSR 与 Nuxt

SSR 是 Server-Side Rendering,即服务端渲染的英文缩写。

Vue.js 是一个用于构建客户端应用的框架。默认情况下,Vue 组件的职责是在浏览器中生成和操作 DOM。在客户端是单页应用 (SPA) 。

也可以将 vue 程序在服务端渲染,渲染完成再返回给浏览器,最后在浏览器端将返回的 HTML 激活(hydrate),这个过程就是 SSR。

用 SSR 的好处:

  • 更快的首屏加载
  • 更好的 SEO

构建一套完整的 SSR 应用会很复杂,Nuxt 很好的解决了这个问题,让 Vue 的服务端渲染变得更加简单。

Nuxt 是一个构建于 Vue 生态系统之上的全栈框架,它为编写 Vue SSR 应用提供了丝滑的开发体验。还可以把它当作一个静态站点生成器来用!简单来说, Nuxt 是 Vue服务端渲染的通用解决方案。

Nuxt2 版本是基于 Vue2.x 版本的,Nuxt3 版本是基于 Vue3.x 版本的,目前 Nuxt3处于RC版本。本文基于 Nuxt3,官网传送门。

前置准备

  • 开发工具:VS Code
  • VS Code插件:Vue Language Features(Volar)
  • VS Code插件:TypeScript Vue Plugin(Volar)
  • node版本需要高于v14.16.0

安装

创建项目:

pnpm dlx nuxi init learn-nuxt3 

进入项目目录:

cd learn-nuxt3 

安装依赖:

pnpm install --shamefully-hoist 

启动项目:

pnpm run dev 

入口组件

app.vue 是 Nuxt3 的入口组件,在 Nuxt3 中如果没有pages/目录,则表示不会包含vue-router依赖。不需要路由就可以这样做。

<template><div>Hello Nuxt3!</div>
</template> 

当应用需要使用路由时,就要在根目录下创建pages文件夹目录。此时,需要使用 <NuxtPage> 路由出口组件:

<template><div><!-- 路由出口 --><NuxtPage/></div>
</template> 

在我们的项目根目录下创建 pages 目录,并修改 app.vue 文件。

路由

创建了pages文件夹目录后,Nuxt会自动集成vue-router,并根据pages目录下的文件名自动生成路由。这种形式称为 约定路由

pages 目录下创建 index.vue 为默认页,创建 about.vue:

<template><div><h1>关于我们</h1></div>
</template> 

此时访问 http://localhost:端口号/about,就会进入 关于我们 的页面,表明 Nuxt 已经为我们自动生成路由了。访问 http://localhost:端口号 就是默认的 index.vue 页面。

动态路由

把动态的参数放到[]中括号中,会生成动态路由。

创建user/[id].vue:

<template><div><h1>用户页</h1></div>
</template>

<script setup lang="ts"></script> 

访问 http://localhost:端口号/user/xxx,会进入到 用户页。

直接访问 http://localhost:端口号/user,会出现404页面,此时可以 创建 user/index.vue 作为默认页。

也可以将[]应用到文件夹名称上或者混合使用,如:user-[role] user-[id].vue

路由参数

  • $route.params 获取路由参数,例如:/user/1,可以得到{ id: 1 }对象
  • $route.query 获取query参数,例如:/user/1?name=tom,可以得到{ name: 'tom' }对象
<template><div><h1>用户页</h1><p>用户id:{{ $route.params.id}}</p></div>
</template> 

在 js 中使用路由参数,可以通过 Vue3 setup 中的useRoute方法:

<script setup lang="ts">const route = useRoute()console.log(route.params)console.log(route.query)
</script> 

路由跳转

Nuxt3 中路由跳转可以使用 <NuxtLink> 组件进行跳转。

user/index.vue中:

 <div><h1>用户默认页</h1><NuxtLink to="user/1">用户1</NuxtLink> |<NuxtLink to="user/2">用户2</NuxtLink> |<NuxtLink to="user/3">用户3</NuxtLink></div> 

嵌套路由

  • 目录和文件同名 (同级目录下)
  • 使用 <NuxtChild> 组件作为子组件出口,类似于 vue-router 中的 <RouterView>

在根目录下新建 parent 文件夹目录 和 parent.vue 文件,在 parent 下新建 child.vue,目录结构如下:

-| pages/
---| parent/
------| child.vue
---| parent.vue 

parent/child.vue

<template><div><h6> pages/parent/child.vue </h6></div>
</template>

<script setup lang="ts"></script> 

parent.vue

<template><div class="box"><h1> pages/parent.vue </h1><NuxtChild /></div>
</template>

<script setup lang="ts"></script>

<style> .box {border: 2px solid #aa0089;} </style> 

此时可以访问 http://localhost:端口号/parent/child,显示 child.vue 的内容。

当然也可以在 parent 目录下新建 index.vue,访问 http://localhost:端口号/parent时就会默认显示 pages/parent.vueparent/index.vue 嵌套的内容。如果没有这个 parent/index.vue,访问 /parent 时,就只会显示 pages/parent.vue 的内容。

页面head元素处理

设置页面标题:

  • <Title> 标签
<Title>关于我们</Title> 
  • useHead 方法,可以为页面设置标题、meta信息等
 useHead({title: '关于我们-'}) 

使用自带的模板方法:

 useHead({title: '关于我们-',titleTemplate(title) {return title ? `xx网站 - ${title}` : 'xx网站'},}) 

添加meta信息:

 useHead({// ...meta: [{ name: 'description', content: '网页的描述'},{ name: 'keywords', content: '关键字1'},]}) 

给 body 添加 class样式:

<style> .red {color: red;} </style> 
 useHead({// ...bodyAttrs: {class: 'red'}}) 

加载js文件:

 useHead({// ...script: [{src: 'assets/a.js',body: true}]}) 

静态资源文件

根目录下新建 publicassets 文件用于存放静态资源文件,将两个目录下都放上一张1.png的图片,在 about 页面中使用:

 <!--assets --><img src="~/assets/1.png" alt=""><!-- public --><img src="/1.png" alt=""> 

可复用逻辑

将可复用的逻辑存放在composables目录下,会被自动识别导入到应用程序,以便在全局范围内使用。

新建 composables/useAge.ts:

export const useAge = () => {return useState('age', () => 18)
} 

使用:

<script setup lang="ts">const age = useAge()console.log(age.value)
</script> 

最后

为大家准备了一个前端资料包。包含54本,2.57G的前端相关电子书,《前端面试宝典(附答案和解析)》,难点、重点知识视频教程(全套)。



有需要的小伙伴,可以点击下方卡片领取,无偿分享

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/56632.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【GD-1开发板】CH340驱动安装方法

CH340驱动安装方法正常情况异常情况CH340驱动安装步骤现在国产ARM替代STM32的arm芯片运动正如火如荼进行中&#xff0c;我也录制了一套完整的”ARM嵌入式开发入门教程“&#xff0c;并配套了一个GD32F103C8T6的开发板。 但有小伙伴拿到板子后&#xff0c;说下载程序的时候&…

实验七:定时/计数器8253、8254

目录 例实验目的实验内容报告要求例 已知8253的两个计数器CLK0=1MHZ,CLK1=1KHZ,现系统要求8253的OUT1产生0.1s的定时方波信号。 (1):应如何实现? (2):说明两个计数器的工作方式并计算计数初值 (3):编写初始化程序(8253的端口地址80H-83H,均采用二进制计数) C…

详解torch.nn.functional.grid_sample函数(通俗易懂):可实现对特征图的水平/垂直翻转

一、函数介绍 Pytorch中grid_sample函数的接口声明如下&#xff0c;具体网址可以点这里 torch.nn.functional.grid_sample(input, grid, mode‘bilinear’, padding_mode‘zeros’, align_cornersNone) 为了简单起见&#xff0c;以下讨论都是基于如下参数进行实验及讲解的&…

BSN开放联盟链“中移链”浏览器2.0正式发布!

由中国移动信息技术中心自主研发的中移链EOS区块链浏览器2.0版本&#xff0c;已在区块链服务网络&#xff08;BSN&#xff09;官网和BSN-DDC网络官网正式发布。 中移链浏览器2.0 无论是从政策导向还是从业务需求方面来说&#xff0c;区块链技术的发展已经是一种不可逆的趋势&a…

查找-二叉排序树

问题引入 【问题描述】 输入若干个整数建立二叉排序树,以0结束输入,在二叉排序树上查找关键字,删除指定关键字结点。 【输入形式】 (1)第一行,输入若干个整数,输入0结束输入; 如输入关键字 45 24 53 12 28 90 0 可建立如下二叉排序树 (2)第二行,输入两个整数,一…

GameOff2022参与有感

GameOff2022参与有感以及年度总结 厚颜无耻的用我们美术的立绘 GameOff— Redemption 很高兴在一个月的时间里面和大家一起完成了《Redemption》 比赛链接&#xff1a;Itch.io 百度云盘链接&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1ylK0QRr2lmkqi4JF1wsXtA 提…

【servelt原理_6_servlet核心接口和类】

servlet核心接口和类 在Servlet体系中&#xff0c;除了实现servlet接口,还可以通过继承GenericServlet或HttpServlet类实现编写1.Servlet接口 servlet接口是整个servlet的核心。它是所有Servlet类必须直接或者间接实现的一个接口&#xff0c;其内部需要实现的5个方法分别关乎…

基于flv.js的视频自动播放

1: html <video class"video-content" id"video">您的浏览器不支持 HTML5 video&#xff01; </video> 2: 创建flv实例并播放 let videoPlayer document.getElementById(video); //获取html if (flvJs.isSupported()) {//创建flv实例this.P…

音视频开发——FFmpeg技术点 【进阶一览】

概述 Fmpeg是一套领先的音视频多媒体处理开源框架&#xff0c;采用LGPL或GPL许可证。它提供了对音视频的采集、编码、解码、转码、音视频分离、合并、流化、过滤器等丰富的功能&#xff0c;包含了非常先进的音频/视频编解码库libavcodec&#xff0c;具有非常高的可移植性和编解…

[附源码]计算机毕业设计中小学课后延时服务管理系统Springboot程序

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

Git 之 已有项目创建 git 仓库

Git 之 已有项目创建 git 仓库前言一、现在 github/gitee 中创建仓库二、在项目的文件夹当中 git bash here1.git init2. git remote add origin 仓库地址3. git pull origin master4. git add . git commit -m git push -u origin master前言 项目已经开始写了,但是还没有…

干货 | 数字经济创新创业——如何造就成功的职业生涯

下文整理自清华大学大数据能力提升项目能力提升模块课程“Innovation & Entrepreneurship for Digital Economy”&#xff08;数字经济创新创业课程)的精彩内容。主讲嘉宾&#xff1a;Kris Singh: CEO at SRII, Palo Alto, CaliforniaVisiting Professor of Tsinghua Unive…

第一天:Python元学习——通用人工智能的实现

文章目录0 封面1 第一章&#xff1a;元学习简介1.1 元学习与少样本学习1.2 元学习的类型——学习度量空间1.3 学习初始化1.4 学习优化器1.5 通过梯度下降来学习如何通过梯度下降来学习2 第二章&#xff1a;使用孪生网络进行人脸识别与音频视频2.1 什么是孪生神经网络孪生神经网…

机器学习与数据挖掘——数据预处理

如果有兴趣了解更多相关内容&#xff0c;欢迎来我的个人网站看看&#xff1a;瞳孔空间 一&#xff1a;关于数据预处理 在工程实践中&#xff0c;我们得到的数据会存在有缺失值、重复值等&#xff0c;在使用之前需要进行数据预处理。数据预处理没有标准的流程&#xff0c;通常…

Kaldi的简单介绍和基本使用说明

Kaldi的简单介绍和基本使用说明前言一、ASR简介1.语音识别系统特征提取&#xff1a;声学模型发音词典语言模型语音解码2. ASR项目二、Kaldi简介三、Kaldi项目的结构四、Kaldi的安装1. 安装依赖的几个系统开发库2. 安装依赖的第三方工具库3. 编译Kaldi代码配置Kaldi编译Kaldi五、…

Python-进程和线程

张钊*&#xff0c;沈啸彬*, 王旭* 李月&#xff0c;曹海艳&#xff0c; (淮北师范大学计算机科学与技术学院&#xff0c;淮北师范大学经济与管理学院&#xff0c;安徽 淮北) *These authors contributed to the work equllly and should be regarded as co-first authors. &a…

智能电网中需求响应研究(Matlab代码实现)

目录 1 概述 2 运行结果 ​编辑 ​编辑 3 参考文献 4 Matlab代码实现 1 概述 智能电网需求响应可以降低电网高峰用电需求、提高电网运行稳定性和可靠性&#xff0c;尤其是通过需求响应实现电网接纳间歇性可再生能源发电的能力。 需求响应的全球进展及产生的效益等情况在…

SDUT—Python程序设计实验1011(面向对象)

7-1 sdut-oop-2 Shift Dot(类和对象&#xff09; 给出平面直角坐标系中的一点&#xff0c;并顺序给出n个向量&#xff0c;求该点根据给定的n个向量位移后的位置。 设计点类Point&#xff0c;内含&#xff1a; &#xff08;1&#xff09;整型属性x和y&#xff0c;表示点的横坐标…

数据可视化之交通可视化

一 前言 智慧城市的概念自 2008年提出以来&#xff0c;在国际上引起广泛关注&#xff0c;并持续引发了全球智慧城市的发展热潮。智慧城市已经成为推进全球城镇化、提升城市治理水平、破解大城市病、提高公共服务质量、发展数字经济的战略选择。近年来&#xff0c;我国智慧城市…

rxjs pipeable operators(上)

rxjs pipeable operators&#xff08;上&#xff09; A Pipeable Operator is a function that takes an Observable as its input and returns another Observable. It is a pure operation: the previous Observable stays unmodified. 一个 Pipeable Operator 是一个接受一个…