nuxt3使用记录四:加载静态资源时路径的写法研究

在上一篇记录了NUXT进行SSG构建时,不仅会构建纯静态的html文件,也会构建一堆js文件。而如果网页中有加载静态资源,如图片,这时就需要注意了,不能简单的使用官网说的<img src="~/assets/img/nuxt.png" alt="Discover Nuxt 3" />这个~的相对路径引入资源在构建的html文件中有问题

演示代码结构

首先,我在pages目录下有个index.vue,里面只是简单的路由跳转

// pages/index.vue
<template><NuxtLink to="/page1">测试</NuxtLink>
</template>

然后还有个pages.vue编写测试的内容:

// pages/page1.vue
<template><div><img src="assets/logo1.jpg" /><img src="/assets/logo2.jpg" /><img src="~/assets/logo3.jpg" /><img :src="img4" /><img :src="img5" /><img :src="img6" /><img :src="img7" /><img :src="img8" /><img :src="img9" /><img :src="img10" /><img :src="img11" /><img :src="img12" /></div>
</template>
<script lang="ts" setup>const img4 = ref(new URL("assets/logo4.jpg", import.meta.url).href);const img5 = ref(new URL("/assets/logo5.jpg", import.meta.url).href);const img6 = ref(new URL("~/assets/logo6.jpg", import.meta.url).href);const img7 = new URL("assets/logo7.jpg", import.meta.url).hrefconst img8 = new URL("/assets/logo8.jpg", import.meta.url).hrefconst img9 = new URL("~/assets/logo9.jpg", import.meta.url).hrefconst img10 = "assets/logo10.jpg"const img11 = "/assets/logo11.jpg"const img12 = "~/assets/logo12.jpg"
</script>

直接运行代码,相当于服务端渲染

资源在assets目录中的情况

当点击跳转链接跳转时:

在这里插入图片描述
前9张图片加载成功,它们的加载路径都是形如:http://localhost:3000/_nuxt/assets/logo1.jpg // 相应图片对应相应数字
而后3张失败,看看他们被转化成的路径:

GET http://localhost:3000/assets/logo10.jpg 404 (Page not found: /assets/logo10.jpg)
GET http://localhost:3000/assets/logo11.jpg 404 (Page not found: /assets/logo11.jpg)
GET http://localhost:3000/~/assets/logo12.jpg 503 (Service Unavailable)

我找了下他的加载资源里,有个page1.vue的文件,这个文件就和构建时编译成js文件是一样的。里面有转成上述路径的代码,这里的转化我认为都是合理的,用new URL("XXX", import.meta.url).href包裹一下,各种格式都能转化成正确的,所以建议使用。
可以得出以下结论

  1. 直接写在template的路径,三种写法都能被正确转化成正确的路径
  2. new URL("XXX", import.meta.url).href包裹的写法也都OK
  3. 直接字符串的路径,nuxt也不会帮忙做转化,直接被拼接到根路径上,导致没有最外层路径_nuxt/而出错
直接刷新路由

但是,如果手动刷新该路由,就不那么理想了
在这里插入图片描述
失败了后9个script中的,可以发现在请求中多了个文档page1,其核心内容:

 <div data-v-inspector="pages/page1.vue:2:5"><img src="/_nuxt/assets/logo1.jpg" data-v-inspector="pages/page1.vue:3:9"><img src="/_nuxt/assets/logo2.jpg" data-v-inspector="pages/page1.vue:4:9"><img src="/_nuxt/assets/logo3.jpg" data-v-inspector="pages/page1.vue:5:9"><img src="file:///E:/workSpace/web/nuxtTest2/pages/assets/logo4.jpg" data-v-inspector="pages/page1.vue:6:9"><img src="file:///E:/assets/logo5.jpg" data-v-inspector="pages/page1.vue:7:9"><img src="file:///E:/workSpace/web/nuxtTest2/pages/~/assets/logo6.jpg" data-v-inspector="pages/page1.vue:8:9"><img src="file:///E:/workSpace/web/nuxtTest2/pages/assets/logo7.jpg" data-v-inspector="pages/page1.vue:9:9"><img src="file:///E:/assets/logo8.jpg" data-v-inspector="pages/page1.vue:10:9"><img src="file:///E:/workSpace/web/nuxtTest2/pages/~/assets/logo9.jpg" data-v-inspector="pages/page1.vue:11:9"><img src="assets/logo10.jpg" data-v-inspector="pages/page1.vue:12:9"><img src="/assets/logo11.jpg" data-v-inspector="pages/page1.vue:13:9"><img src="~/assets/logo12.jpg" data-v-inspector="pages/page1.vue:14:9"></div>

可以看到,4、5、6被转化为本地文件路径了!所以这里可以确定三件事情:

  1. 如第三篇所讲的,页面的路由跳转加载的是.js文件,而直接刷新路由加载的是编译好的静态.html文件
  2. 构建静态html文件时,写在script中的相对路径全部被转化成了file:///开头的本地文件路径
  3. 写在script中纯字符串,依然不会做任何处理

资源在public文件夹中的情况

根据官方文档,public相当于项目的根目录,可直接引用资源。上面page1.vue的路径,去掉assets/就是public的引用形式,其他不变,接着测试:

然后第一步就报错了,编译是logo1和3的写法直接不该通过,所以直接去掉了。

点击路由跳转的方式

在这里插入图片描述

看,只有3个能加载成功,其余失败的被转化成如下路径

GET http://localhost:3000/_nuxt/pages/logo7.jpg 503 (Service Unavailable)
GET http://localhost:3000/_nuxt/@fs/logo8.jpg 503 (Service Unavailable)
GET http://localhost:3000/_nuxt/logo9.jpg 503 (Service Unavailable)
GET http://localhost:3000/~/logo12.jpg 503 (Service Unavailable)
GET http://localhost:3000/_nuxt/pages/logo4.jpg 404 (Page not found: /_nuxt/pages/logo4.jpg)
GET http://localhost:3000/_nuxt/logo6.jpg 404 (Page not found: /_nuxt/logo6.jpg)
GET http://localhost:3000/_nuxt/@fs/logo5.jpg 404 (Page not found: /_nuxt/@fs/logo5.jpg)

加载成功的路径是:http://localhost:3000/logo1.jpg

官网也介绍了,public中的资源会被放在根目录下,所以正确的加载方式是不要~,直接使用\开头即可引用。

所以,public中的资源文件,不要用new URL("XXX", import.meta.url).href包裹,直接纯字符串且像根目录文件一样引用

手动刷新路由

在这里插入图片描述

<div data-v-inspector="pages/page1.vue:2:5"><img src="/logo2.jpg" data-v-inspector="pages/page1.vue:4:9"><img src="file:///E:/workSpace/web/nuxtTest2/pages/logo4.jpg" data-v-inspector="pages/page1.vue:6:9"><img src="file:///E:/logo5.jpg" data-v-inspector="pages/page1.vue:7:9"><img src="file:///E:/workSpace/web/nuxtTest2/pages/~/logo6.jpg" data-v-inspector="pages/page1.vue:8:9"><img src="file:///E:/workSpace/web/nuxtTest2/pages/logo7.jpg" data-v-inspector="pages/page1.vue:9:9"><img src="file:///E:/logo8.jpg" data-v-inspector="pages/page1.vue:10:9"><img src="file:///E:/workSpace/web/nuxtTest2/pages/~/logo9.jpg" data-v-inspector="pages/page1.vue:11:9"><img src="logo10.jpg" data-v-inspector="pages/page1.vue:12:9"><img src="/logo11.jpg" data-v-inspector="pages/page1.vue:13:9"><img src="~/logo12.jpg" data-v-inspector="pages/page1.vue:14:9">
</div>

和在assets中有相似的转化,所以在public中的写法建议就是直接字符串"/logo11.jpg"这样引用

PS:强烈建议资源不要直接放在public内,而是再建一个子目录。因为构建打包时public内的文件、文件夹会被原样搬到打包好的根目录下,导致根目录内一堆图片,很乱,还不利于写静态资源代理

SSG构建后再运行

资源在assets目录中的情况

当点击跳转链接跳转时

在这里插入图片描述
前9个纯静态的,直接被转化成base64了,已经不是路径了

直接刷新路由

在这里插入图片描述
再看转化后的html文件:

<div><img src="data:image/jpeg;base64,... >	<img src="data:image/jpeg;base64,... >	<img src="data:image/jpeg;base64,... >	<img src="file:///E:/workSpace/web/nuxtTest2/.nuxt/prerender/assets/logo4.jpg"><img src="file:///E:/assets/logo5.jpg"><img src="file:///E:/workSpace/web/nuxtTest2/.nuxt/prerender/~/assets/logo6.jpg"><img src="file:///E:/workSpace/web/nuxtTest2/.nuxt/prerender/assets/logo7.jpg"><img src="file:///E:/assets/logo8.jpg"><img src="file:///E:/workSpace/web/nuxtTest2/.nuxt/prerender/~/assets/logo9.jpg"><img src="assets/logo10.jpg"><img src="/assets/logo11.jpg"><img src="~/assets/logo12.jpg">
</div>

资源在public文件夹中的情况

当点击跳转链接跳转时

多了个5和8可以正常
在这里插入图片描述

直接刷新路由

和上面直接运行的结果一样:
在这里插入图片描述

所以,服务端渲染和SSG纯静态运行时,结果还是有不小区别

总结

静态资源在assets中

资源路径要直接纯字符串写在template中,才能通杀

静态资源在public中

资源路径可以在templatescript中直接一纯字符串的形式写,不要用new URL包裹

我认为nuxt对静态资源的处理,仍有缺陷!

如果是非纯静态的页面呢?

虽然我的主题是SSG,但是并不意味着页面就不需要与用户交互了,比如需求是:网页初始化时有默认的图片,然后用户可以手工改变图片,比如上传自己的图片

我摸索出来的稳定写法是使用三木运算符做动态切换:

<template><div><img :src="img ? img : '/logo1.jpg'" /></div>
</template>
<script lang="ts" setup>const img = ref<string | undefined>();
</script>

然后在script中动态改变图片,可以将图片转化成base64赋值给ref对象,也可以是一个完整的网络地址

本质上仍然是直接在template中写字符串路径。只有这样,才能应对服务端渲染纯SSG构建点击跳转路由手动刷新页面这几种情况!

希望nuxt能更智能的处理静态资源路径问题,特别是构建的js文件和html文件,能做到统一!!!!

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

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

相关文章

Linux进阶---常见符号及其含义、常见报错

一、常见符号及其含义&#xff08;重要&#xff09; 二、 常见报错 • 找不到文件、文件不存在&#xff1a;No such file or directory • 没有权限 &#xff1a;Permission denied • 命令不存在 &#xff1a;command not found 1.找不到文件、文件不存在&#xff1a;No s…

AI智能电销机器人是什么?能给我们带来哪些便利?

科技的飞速发展&#xff0c;让很多“懒人”的幻想变成了现实&#xff0c;越来越多的人工智能产品被发明出来甚至完全替代日常生活中的工作。比如在电销行业&#xff0c;很多企业选择AI智能电销机器人进行外呼。那么你了解多少AI智能电销机器人呢&#xff1f;和小编kelaile520一…

声明v.s.定义

参考&#xff1a;http://t.csdnimg.cn/1xnzA 变量的定义&#xff1a;用于为变量分配存储空间&#xff0c;还可以为变量指定初始值&#xff0c;在程序中&#xff0c;变量有且仅有一个定义。变量的声明&#xff1a;用于向程序表明变量的类型和名字。在程序中&#xff0c;变量可以…

SAP SD学习笔记06 - 受注的据否,受注的理由,简易变更(一括处理)

上文讲了一括处理和Block&#xff08;冻结&#xff09;处理。 SAP SD学习笔记05 - SD中的一括处理&#xff08;集中处理&#xff09;&#xff0c;出荷和请求的冻结&#xff08;替代实现承认功能&#xff09;-CSDN博客 本章继续讲SAP的流程中一些常用的操作。 1&#xff0c;受注…

Flume 入门教程

内容目录 Flume 简介 架构和基本概念 多种架构模式 Flume 安装部署 Flume 简介 Flume 是一个分布式、可靠且高可用的数据收集、聚合和传输系统&#xff0c;主要用于高效地处理大规模日志数据。设计之初&#xff0c;它主要服务于日志管理领域&#xff0c;但其灵活性和可扩展…

语言的未来:深度学习在自然语言处理中的革命

语言的未来&#xff1a;深度学习在自然语言处理中的革命 1 引言 自古以来&#xff0c;语言就是人类表达思想、传递信息、进行社会互动的基石。语言的复杂性既体现在其变化多端的语义、句法和语用层面&#xff0c;同时也反映在人类如何理解和产生自然语言的深奥之中。在这一节中…

009、Python+fastapi,第一个后台管理项目走向第9步:ubutun 20.04下安装vscode+git环境配置

一、说明 git是一定要配置的&#xff0c;由于是白嫖的无影云电脑&#xff0c;东西得保存在网上&#xff0c;就继续白嫖gitee吧&#xff0c;显然国内github是不太合适的了 二、安装git 直接安装sudo apt install -y git git --version git version 2.25.1 三、配置git 在git上…

OSPF星型拓扑和MGRE全连改

一&#xff0c;拓扑 二&#xff0c;要求 1&#xff0c;R6为ISP只能配置IP地址&#xff0c;R1-R5的环回为私有网段 2&#xff0c;R1/4/5为全连的MGRE结构&#xff0c;R1/2/3为星型的拓扑结构&#xff0c; 3&#xff0c;R1为中心站点所有私有网段可以互相通讯&#xff0c;私有网段…

Spring AI,调用OpenAI大模型接口,让ChatGPT给你讲笑话

前言 Spring最近刚刚推出了SpringAI&#xff0c;封装了AI大模型接口的使用。本文将参考Spring官网案例&#xff0c;一步步教你如何调用OpenAI的接口&#xff0c;让ChatGPT接口返回一个笑话。 前提条件 请下载并安装好JDK17或更新的版本&#xff0c;本文使用的是JDK21。JDK下…

基于百度文心大模型全面重构,小度正式推出AI原生操作系统DuerOS X

4月16日&#xff0c;以“创造未来”为主题的2024百度Create AI开发者大会在深圳举办。百度集团副总裁、小度科技CEO李莹正式发布了小度新一代操作系统DuerOS X&#xff0c;该操作系统是小度基于百度文心大模型推出的全球首个AI原生操作系统。李莹表示&#xff1a;“作为⽂⼼⼤模…

【漏洞复现】IP-guard WebServer getdatarecord接口处存在权限绕过漏洞

免责声明&#xff1a;文章来源互联网收集整理&#xff0c;请勿利用文章内的相关技术从事非法测试&#xff0c;由于传播、利用此文所提供的信息或者工具而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者本人负责&#xff0c;所产生的一切不良后果与文章作者无关。该…

基于Java+Vue的校园交友系统(源码+文档+包运行)

一.系统概述 选题背景&#xff1a; 在大学校园中&#xff0c;学生们面临着新的环境和人际关系的挑战。有些学生可能感到孤独或者希望扩展自己的社交圈子&#xff0c;寻找志同道合的朋友或者潜在的伴侣。因此&#xff0c;设计一款校园交友平台具有重要意义。 研究意义&#xff1…

Java内存模型和 JVM 内存运行时

文章目录 前言一、什么是Java 的内存模型&#xff1f;二、什么是 JVM 的运行时数据区Java8 之前和之后的区别JVM 内存模型JVM 内存区域JVM 内存垃圾回收JVM如何判断哪些对象不在存活&#xff1f;JVM运行过程中如何判断哪些对象是垃圾&#xff1f; JVM 垃圾回收Java8 中的 jvm如…

Google DeepMind: Many-Shot vs. Few-Shot

本文介绍了如何通过增大上下文窗口&#xff0c;利用大型语言模型&#xff08;LLMs&#xff09;进行多实例上下文学习&#xff08;Many-Shot In-Context Learning&#xff0c;ICL&#xff09;的方法。主要描述了现有的几实例上下文学习方法虽然在推理时能够通过少量例子学习&…

“全网最全”LLM推理框架集结营 | 看似微不足道,却决定着AIGC项目的成本、效率与性能!

00-前序 随着ChatGPT、GPT-4等大语言模型的出现&#xff0c;彻底点燃了国内外的学者们与企业家们研发LLM的热情。国内外的大语言模型如雨后春笋一般的出现&#xff0c;这些大语言模型有一部分是开源的&#xff0c;有一部分是闭源的。 伴随着大语言模型的出现&#xff0c;国内外…

树莓派驱动RGB灯-rpi-ws281x库安装

1 树莓派的操作系统安装 1.1 操作系统选择 这个选择64位的操作的系统来驱动&#xff0c;一定不要选择32位的操作系统。笔者在这个地方浪费不少时间&#xff0c;具体原因不是很清楚。如果32位的操作系统&#xff0c;后面在rpi-ws281x的库时候会有报错。 1.2 操作系统链接如下…

windows docker desktop==spark环境搭建

编写文件docker-compose.yml version: 3services:spark-master:image: bde2020/spark-master:3.1.1-hadoop3.2container_name: spark-masterports:- "8080:8080"- "7077:7077"- "2220:22"volumes:- F:\spark-data\m1:/dataenvironment:- INIT_D…

Spring学习(三)——AOP

AOP是在不改原有代码的前提下对其进行增强 AOP(Aspect Oriented Programming)面向切面编程&#xff0c;在不惊动原始设计的基础上为其进行功能增强&#xff0c;前面咱们有技术就可以实现这样的功能即代理模式。Java设计模式——代理模式-CSDN博客 基础概念 连接点&#xff08…

2024经常用且免费的10个网盘对比,看看哪个比较好用!

网盘在我们的工作和学习中经常会用到&#xff0c;也是存储资料的必备工具&#xff0c;有了它&#xff0c;我们就不用走到哪都带着移动硬盘了&#xff0c;而目前市场上的主流网盘还有数十款&#xff0c;其中有免费的也有付费的&#xff0c;各家不一&#xff0c;今天小编就来为您…

[Android]模拟器登录Google Play失败

问题&#xff1a; 模拟器登录Google Play失败&#xff0c;提示couldnt sign in there was a problem communicating with google servers. try again later. 原因&#xff1a; 原因是模拟器没有连接到互联网&#xff0c;打开模拟器中Google浏览器进行搜索一样不行。 解决&am…