您好,登錄后才能下訂單哦!
場(chǎng)景
吾輩在使用 Vuetify 時(shí)突然遇到的,明明 img
標(biāo)簽就可以使用相對(duì)路徑獲取到圖片,而 Veutify 的組件 v-img
卻不能使用。
如下面 3 種加載圖片的方式
<!-- 正常加載 --> <v-img :src="require('../../assets/logo.png')" /> <!-- 無(wú)法加載 --> <v-img src="../../assets/logo.png" /> <!-- 正常加載 --> <img src="../../assets/logo.png" />
吾輩在 segmentfault 上的提問(wèn)
原因
是的,居然必須用 require()
引入圖片才能生效,那為什么 img
標(biāo)簽可以直接使用相對(duì)路徑呢?這和 vue-loader 資源路徑處理 有關(guān)系。
官方明確指出會(huì)將所有資源路徑作為模塊依賴,也就是后臺(tái) vue-loader
幫我們轉(zhuǎn)換成 require()
的形式了。
解決方案
vue cli 3
vue cli 3 的配置項(xiàng) API 發(fā)生了改變,由 transformToRequire
改為 transformAssetUrls
,而且配置方式也不再是直接修改 webpack 配置文件,而是修改 vue.config.js
這個(gè)經(jīng)過(guò)包裝后的文件。現(xiàn)在,最新的配置方式如下
module.exports = { chainWebpack: config => { config.module .rule('vue') .use('vue-loader') .loader('vue-loader') .tap(options => { return { ...options, //修復(fù)靜態(tài)資源引用的問(wèn)題 vue cli 2 => vue cli 3 升級(jí)之后配置項(xiàng)由 transformToRequire 改為 transformAssetUrls transformAssetUrls: { video: ['src', 'poster'], source: 'src', img: 'src', image: 'xlink:href', // 在這里添加需要使用靜態(tài)資源的自定義元素 'a-avatar': 'src', }, } }) }, }
具體參考
Vue Loader => 從 v14 遷移 => 廢棄的選項(xiàng)
Vue Cli 3 => webpack 相關(guān) => 鏈?zhǔn)讲僮?(高級(jí)) => 修改 Loader 選項(xiàng)
vue cli 2
那么,Veutify 組件中的 src
不能使用相對(duì)路徑的原因就很明確了。因?yàn)?vue-loader
并不知道我們要把 v-img
的 src
屬性轉(zhuǎn)換成 require()
依賴。我們找到 vue-loader
配置處,在 options.transformToRequire
中加上 v-img
即可
// vuetify 框架的 src 標(biāo)簽也需要自動(dòng)轉(zhuǎn)換為 require 'v-img': 'src'
吾輩的配置文件在 build > vue-loader.conf.js
'use strict' const utils = require('./utils') const config = require('../config') const isProduction = process.env.NODE_ENV === 'production' const sourceMapEnabled = isProduction ? config.build.productionSourceMap : config.dev.cssSourceMap module.exports = { loaders: utils.cssLoaders({ sourceMap: sourceMapEnabled, extract: isProduction, }), cssSourceMap: sourceMapEnabled, cacheBusting: config.dev.cacheBusting, transformToRequire: { video: ['src', 'poster'], source: 'src', img: 'src', image: 'xlink:href', 'v-img': 'src', }, }
vue-loader 官方文檔參考
然后重啟 npm run dev
刷新一下就行啦
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。