Vue 自定义标签的src属性不能使用相对路径的解决

2020-06-13 06:03:30易采站长站整理

场景

吾辈在使用 Vuetify 时突然遇到的,明明

img
标签就可以使用相对路径获取到图片,而 Veutify 的组件
v-img
却不能使用。

如下面 3 种加载图片的方式


<!-- 正常加载 -->
<v-img :src="require('../../assets/logo.png')" />
<!-- 无法加载 -->
<v-img src="../../assets/logo.png" />
<!-- 正常加载 -->
<img src="../../assets/logo.png" />

吾辈在 segmentfault 上的提问

原因

是的,居然必须用

require()
引入图片才能生效,那为什么
img
标签可以直接使用相对路径呢?这和 vue-loader 资源路径处理 有关系。

官方明确指出会将所有资源路径作为模块依赖,也就是后台

vue-loader
帮我们转换成
require()
的形式了。

解决方案

vue cli 3

vue cli 3 的配置项 API 发生了改变,由

transformToRequire
改为
transformAssetUrls
,而且配置方式也不再是直接修改 webpack 配置文件,而是修改
vue.config.js
这个经过包装后的文件。现在,最新的配置方式如下


module.exports = {
chainWebpack: config => {
config.module
.rule('vue')
.use('vue-loader')
.loader('vue-loader')
.tap(options => {
return {
...options,
//修复静态资源引用的问题 vue cli 2 => vue cli 3 升级之后配置项由 transformToRequire 改为 transformAssetUrls
transformAssetUrls: {
video: ['src', 'poster'],
source: 'src',
img: 'src',
image: 'xlink:href',
// 在这里添加需要使用静态资源的自定义元素
'a-avatar': 'src',
},
}
})
},
}

具体参考
Vue Loader => 从 v14 迁移 => 废弃的选项
Vue Cli 3 => webpack 相关 => 链式操作 (高级) => 修改 Loader 选项

vue cli 2

那么,Veutify 组件中的

src
不能使用相对路径的原因就很明确了。因为
vue-loader
并不知道我们要把
v-img