Vue CLI 设置 publicPath:打包后的应用可部署在任意路径

前言

领导要重新部署多个应用环境,且不受路径层级影响。
于是找到了 Vue CLI 配置 publicpath

配置说明

下图所示:

  1. '/' :默认值,应用部署在根路径上;
  2. './':注意前面加了一个点,应用可部署在任意路径上。因为 . 点代表相对路径
  3. '':空字符串,同 2 是一个意思,代表相对路径。接着往下看就知道为啥可为空字符串
    在这里插入图片描述

打包

图左侧:相对路径,可部署在任意路径下。不带前缀,这就是为啥设置为空同样可行;
图右侧:绝对路径,只能在路径下,否则找不到相关文件;
在这里插入图片描述

总结

请仔细查看上图,一切尽在图中!强烈建议自己动手实践,会有更深刻的认知~

扩展

1. router 限制

Vue CLI 配置 publicpath下还有一段黄色标注。

  1. Vue Router mode,为 history 无效,建议使用默认值 hash
  2. 多应用暂没使用,此处不赘述;
    在这里插入图片描述

2. 与配置 outputDir 关联关系

注意还有一个配置 outputDir,不要弄混淆了!!
outputDir 的默认值是 dist 。打包生成的文件放在 Vue工程 根目录下,文件夹名称就是 dist
在这里插入图片描述

配置一

  • 默认值,无需配置;
  • 应用必须部署在根路径下;
  • 打包后的文件在 Vue工程 根目录文件夹 dist 下;
module.exports = {publicPath: '/', // 注意这里没有点 .outputDir: 'dist' // 注意结尾无 /
}

配置二

module.exports = {publicPath: './', // 注意这里多个点 .outputDir: 'dist/route/test' // 注意结尾无 /
}
  • publicPath 值开头是 ./ ,说明可部署任意路径下;
  • publicPath 值结尾是 / ,表示某路径下outputDir 值结尾没有 / ,说明是文件夹名称
  • 打包后的文件在Vue 工程dist/route/test下;
    在这里插入图片描述
    dist 文件夹下的文件放入部署环境,打开是 route/test/index.html
    在这里插入图片描述
  • 将部署路径 route/ 改为 route2/同样能访问,只要 publicPath任意路径就行;
  • /route/test/ 下的文件放在其它路径下,url 路径名称对应也可访问;
  • outputDir 仅仅是打包后的文件存放路径,与部署路径无关
    在这里插入图片描述

配置三

module.exports = {publicPath: '/route/test/', // 注意这里没有点 .outputDir: 'dist/route/test' // 注意结尾无 /
}
  • publicPath 值开头是 / ,这就限制了部署路径,必须在部署环境的根路径 /route/test 文件夹下;
  • publicPath 值结尾是 / ,表示某路径下outputDir 值结尾没有 / ,说明是文件夹名称
  • 打包后的文件在Vue 工程dist/route/test下;
    在这里插入图片描述
    部署环境下打开是 route/test/index.html
    在这里插入图片描述
  • 将部署路径 route/ 改为 route2/只能访问 index.html,相关文件就报 404
  • 例如 test.js ,它被限制在部署环境根路径 /route/test/ 下,/route2/test/ 就找不到;
  • outputDir 仅仅是打包后的文件存放路径,与部署路径无关

在这里插入图片描述

配置四

module.exports = {publicPath: './route/test/', // 注意这里多个点 .outputDir: 'dist/route/test' // 注意结尾无 /
}
  • publicPath 值开头是 ./ ,说明可部署任意路径下的 /route/test/ 下;

  • publicPath 值结尾是 / ,表示某路径下outputDir 值结尾没有 / ,说明是文件夹名称

  • 打包后的文件在Vue 工程dist/route/test下;
    在这里插入图片描述

  • 部署环境下打开是 route/test/index.html

  • 但只能访问 index.html,相关文件就报 404,;

  • 例如 test.js ,套了两层 route/test/,第一层 route/test/是部署路径,第二次是配置的 publicPath 路径;

  • 正确配置参考二和三,但建议使用配置三(有限制),推荐配置二;

  • outputDir 仅仅是打包后的文件存放路径,与部署路径无关
    在这里插入图片描述

3. index.html 引入静态文件

讲到这里,我们已经深刻的理解,想要应用部署在任意路径下,开头必须是 ./空字符串。同理,index.html 文件中引入的静态文件路径是:

// 正确
<script src="./tree.js"></script>// 正确
<script src="tree.js"></script>// 正确,参考https://cli.vuejs.org/zh/guide/html-and-static-assets.html#public-%E6%96%87%E4%BB%B6%E5%A4%B9
<script src="<%= BASE_URL %>tree.js"></script>// 应用部署在非根路径下,错误,已限制在根路径下
<script src="/tree.js"></script>

报错,当前应用在 dist 文件夹下找不到。tree.js限制在根路径。
在这里插入图片描述

4. img 标签的图片引用

这里仅说明放在 public 文件夹下的图片在 img 标签中的使用。多说一句, 打包后的public 文件夹文件仅仅是拷贝到默认 dist 目录下。与打包后 src/assets 文件夹下的图片被编译是不同的。
同理,

// 正确
<img class="user-icon" src="./static/images/login.png" />// 正确
<img class="user-icon" src="static/images/login.png" />// 错误:应用部署在非根路径下是找不到的,已限制在根路径下
<img class="user-icon" src="/static/images/login.png" />

5. background-image url 图片引用

同样,这里仅说明放在 public 文件夹下的图片在 background-image url 中的使用。
我们是可以使用 src/assets 文件夹下的图片,但有时就是有用 public 文件夹下图片的场景。便于运维同事,现场更换图片…

方式一

最简单的方式,除了路径有点长…应用部署在任意路径下也可行,亲测有效,哈哈哈…

// 正确:你没看错...就是这么长
background-image: url('../../../public/static/images/login.png');

以下都是错的

// 错误:在 src/static/images 路径下找图片。被webpack解析为 require(src/static/images/login.png) 动态引入
background-image: url('~@/static/images/login.png');// 错误:在 src/static/images 路径下找图片
background-image: url('/static/images/login.png');// 错误:相对路径,在当前 .vue 文件所在路径下找图片,例如文件在 src/views 下。则在 src/views/static/images 下找图片
background-image: url('./static/images/login.png');// 错误:同上
background-image: url('static/images/login.png');

最后,本小节的知识点较多,需要多多消化~可查看 Vue CLI 处理静态资源 去理解。
关于 何时使用 public 文件夹,Vue CLI 也给出了解释。下面是截图,以免你不想进入第三方链接:
在这里插入图片描述

方式二

网上也找到比较复杂的用 CSS 变量 方式,这里不赘述,可 参考;

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

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

相关文章

【Earth Engine】协同Sentinel-1/2使用随机森林回归实现高分辨率相对财富(贫困)制图

目录 1 简介与摘要2 思路3 效果预览4 代码思路5 完整代码6 后记 1 简介与摘要 最近在做一些课题&#xff0c;需要使用Sentinel-1/2进行机器学习制图。 然后想着总结一下相关数据和方法&#xff0c;就花半小时写了个代码。 然后再花半小时写下这篇博客记录一下。 因为基于多次拍…

【Python小游戏】某程序员自制《苹果大赛》,赶紧来抢~“免费的平安夜苹果,你说是不是最甜的鸭?”(附源码)

导语 很久不见&#xff0c;我是木木子鸭~2023发生了太多事情啦&#xff0c;我将重新启航&#xff0c;开启新的一页。 希望不管是文章还是各种小程序都能够帮到大家&#xff0c;大家也要继续支持我哦~我将继续努力更新&#xff01; ——祝你祝我 在这个冬天—— 爱与好运同在 …

车云TCP链路偶现链接失联问题排查

一、问题分析 1.1 车云tcp长连接分析排查 在15:37:32.039上线&#xff0c; 在 16:07:26.527下线&#xff0c;车云长连接通道稳定&#xff0c;且该期间心跳数据正常。 1.2 云向驾仓推送数据分析 在15:37:42 进行车辆接管后&#xff0c;该车辆下线&#xff0c;且无法在上线&am…

AtomHub 开源容器镜像中心开放公测,国内服务稳定下载

由开放原子开源基金会主导&#xff0c;华为、浪潮、DaoCloud、谐云、青云、飓风引擎以及 OpenSDV 开源联盟、openEuler 社区、OpenCloudOS 社区等成员单位共同发起建设的 AtomHub 可信镜像中心正式开放公测。AtomHub 秉承共建、共治、共享的理念&#xff0c;旨在为开源组织和开…

Java中使用JTS实现WKB数据写入、转换字符串、读取

场景 Java中使用JTS实现WKT字符串读取转换线、查找LineString的list中距离最近的线、LineString做缓冲区扩展并计算点在缓冲区内的方位角&#xff1a; Java中使用JTS实现WKT字符串读取转换线、查找LineString的list中距离最近的线、LineString做缓冲区扩展并计算点在缓冲区内…

户用光伏设计有哪些特点?

随着科技的发展和人们对可再生能源的追求&#xff0c;户用光伏设计已经逐渐成为一种新型的能源解决方案。它不仅有助于降低能源成本&#xff0c;而且对环境保护有着积极的影响。那么&#xff0c;户用光伏设计究竟有哪些特点呢&#xff1f; 首先&#xff0c;户用光伏设计的核心在…

c++动态内存与智能指针

前言 静态内存&#xff1a;用于保存局部静态变量、类内的静态数据成员以及全局变量栈&#xff1a;用于保存函数内部的非static变量堆&#xff1a;存储动态分配的对象&#xff08;程序运行时分配的对象&#xff09; 静态内存和栈内存的对象由编译器自动创建和销毁 而堆区的动态…

分布式搜索elasticsearch概念

什么是elasticsearch&#xff1f; elasticsearch是一款非常强大的开源搜索引擎&#xff0c;可以帮助我们从海量数据中快速找到需要的内容 目录 elasticsearch的场景 elasticsearch的发展 Lucene篇 Elasticsearch篇 elasticsearch的安装 elasticsearch的场景 elasticsear…

显示器屏幕oled的性能、使用场景、维护

OLED显示器屏幕具有许多独特的性能和使用场景&#xff0c;以下是关于OLED显示器屏幕的性能、使用场景和维护的详细介绍&#xff1a; 一、性能 色彩鲜艳&#xff1a;OLED显示器屏幕能够呈现出更加鲜艳的色彩&#xff0c;色彩饱和度高&#xff0c;色彩还原性好&#xff0c;可以给…

lv12 根文件系统12

目录 1 根文件系统 2 BusyBox 3 实验九 3.1 在 busybox 官网下载 busybox 源码&#xff08;这里我们下载 busybox-1.22.1.tar.bz2&#xff09; 3.2 拷贝 busybox 源码包到 ubuntu 的家目录下&#xff0c;解压并进入其顶层目录 3.3 进入 busybox 配置界面&#xff08;…

【Midjourney】Midjourney根据prompt提示词生成黑白色图片

目录 &#x1f347;&#x1f347;Midjourney是什么&#xff1f; &#x1f349;&#x1f349;Midjourney怎么用&#xff1f; &#x1f514;&#x1f514;提示词格式 &#x1f34b;&#x1f34b;应用示例——“秘密花园”式涂色书配图生成 &#x1f34c;&#x1f34c;例子1…

SpringMVC系列之技术点定向爆破二

SpringMVC的运行流程 客户端发送请求 tomcat接收对应的请求 SpringMVC的核心调度器DispatcherServlet接收到所有请求 请求地址与RequestMapping注解进行匹配&#xff0c;定位到具体的类和具体的处理方法&#xff08;封装在Handler中&#xff09; 核心调度器找到Handler后交…

【Java 基础】33 JDBC

文章目录 1. 数据库连接1&#xff09;加载驱动2&#xff09;建立连接 2. 常见操作1&#xff09;创建表2&#xff09;插入数据3&#xff09;查询数据4&#xff09;使用 PreparedStatement5&#xff09;事务管理 3. 注意事项总结 Java Database Connectivity&#xff08;JDBC&…

rqt_graph使用说明

其中右边的&#xff1a;/rosout是一个topic 也就是一个话题 /rosout是一个topic 也是一个话题 可以看到凡是在rqt_graph里面用长方形标识的全都是话题 通过观察可以发现&#xff1a;凡是用椭圆标识的全都是节点 如果切换为Nodes only视图会发现&#xff1a; 所说的no…

Java 中的内部类的定义

目录 一、成员内部类 二、静态内部类 三、局部内部类 四、匿名内部类 一、成员内部类 public class InnerClass {String name;private Integer age;static String hobby;/*** 成员内部类* 1、成员内部类中只能定义非静态属性和方法* 2、成员内部类中可以访问外部类的成员&a…

十一.约束(一)

约束 1.约束(constraint)概念1.1为什么需要约束1.2什么是约束1.3约束的分类 2.非空约束2.1作用2.2关键字2.3特点2.4添加非空约束2.5删除非空约束 3.唯一性约束3.1作用3.2关键字3.3特点3.4添加唯一约束3.5关于复合唯一约束3.5删除唯一约束 4.PRIMARY KEY 约束4.1作用4.2关键字4.…

数据分析基础之《numpy(5)—合并与分割》

了解即可&#xff0c;用panads 一、作用 实现数据的切分和合并&#xff0c;将数据进行切分合并处理 二、合并 1、numpy.hstack 水平拼接 # hstack 水平拼接 a np.array((1,2,3)) b np.array((2,3,4)) np.hstack((a, b))a np.array([[1], [2], [3]]) b np.array([[2], […

循环渲染ForEach

目录 1、接口说明 2、键值生成规则 3、组件创建规则 3.1、首次渲染 3.2、非首次渲染 4、使用场景 4.1、数据源不变 4.2、数据源组项发生变化 4.3、数据源数组项子属性变化 5、反例 5.1、渲染结果非预期 5.2、渲染性能降低 Android开发中我们有ListView组件、GridVi…

Apache ShenYu 网关JWT认证绕过漏洞 CVE-2021-37580

Apache ShenYu 网关JWT认证绕过漏洞 CVE-2021-37580 已亲自复现 漏洞名称漏洞描述影响版本 漏洞复现环境搭建漏洞利用 修复建议总结 Apache ShenYu 网关JWT认证绕过漏洞 CVE-2021-37580 已亲自复现) 漏洞名称 漏洞描述 Apache ShenYu是一个异步的&#xff0c;高性能的&#x…

Qt中字符串转换为JS的函数执行

简介 在 QML 中&#xff0c;将 JavaScript 字符串转换为函数通常涉及使用 Function 构造函数或 eval() 函数。但是&#xff0c;QML 的环境对 JavaScript 的支持有一定的限制&#xff0c;因此不是所有的 JavaScript 功能都可以在 QML 中直接使用。 以下介绍都是在Qt5.12.1…