这是开头
最近在试水 Vue CLI 3,并且尝试配置一个多页面(多应用)项目出来,期间又遇到各种路径问题,于是...于是有了下面的唠叨。
以下都是基于 Vue CLI 3 来举例说明的,使用 2.x 版本的其实也类似
首先,参考 官方文档对静态资源处理的说明,并通过自己的实践,可以总结出以下内容
静态资源可以通过两种方式进行处理:
1、以下情况下,资源不会被 webpack 处理,而是被直接拷贝:
- 放置在 public 目录下,即使未被使用。
- 通过绝对路径被引用,即以 / 开头的路径。
2、以下情况下,资源会被 webpack 处理(URL的resolve、minify、uglify、转 base64 等):
- 使用 JavaScript 导入。
- 在 template/CSS 中通过相对路径(即以 . 开头或直接以文件(夹)名开头)被引用。
- URL 以 ~ 开头,其后的任何内容都会作为一个模块请求被解析。
- URL 以 @ 开头,它也会作为一个模块请求被解析(@ 是在 webpack 设置的 alias)。
我们应该根据实际情况去选择我们要引用的资源是否要被处理,然后用对应的、正确的方式去引用它们以达到目的。以下对使用绝对路径和相对路径的方法和注意事项进行描述。
使用绝对路径
默认情况下,Vue CLI 会假设你的应用是被部署在一个域名的根路径上(对应选项 baseUrl: '/'
),例如 https://www.my-app.com/
。如果应用被部署在一个子路径上,你就需要用这个选项指定这个子路径。例如,如果你的应用被部署在 https://www.my-app.com/my-app/,则设置 baseUrl 为 /my-app/。正因为以上的可能情况,我们应该在打算引用纯静态资源(那些不被webpack处理的资源,一般就是 public 目录下的资源)的时候,都确保使用 baseUrl 作为 URL 的开头,以下列举在不同文件中配合 baseUrl 选项写绝对路径的使用方法和注意事项:
在入口html文件中使用
我们可以使用lodash template 语法插入 baseUrl:
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
名称栏目:VueCLI3搭建的项目中路径相关问题的解决-创新互联
网页链接:http://scpingwu.com/article/dcsede.html