欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue 自定義標(biāo)簽的src屬性不能使用相對(duì)路徑的解決

 更新時(shí)間:2019年09月17日 10:50:27   作者:rxliuli  
這篇文章主要介紹了Vue 自定義標(biāo)簽的src屬性不能使用相對(duì)路徑的解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

場(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ò)包裝后的文件?,F(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-imgsrc 屬性轉(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í)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue3?如何通過(guò)虛擬DOM更新頁(yè)面詳解

    Vue3?如何通過(guò)虛擬DOM更新頁(yè)面詳解

    這篇文章主要為大家介紹了Vue3?如何通過(guò)虛擬DOM更新頁(yè)面詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • 對(duì)類Vue的MVVM前端庫(kù)的實(shí)現(xiàn)代碼

    對(duì)類Vue的MVVM前端庫(kù)的實(shí)現(xiàn)代碼

    這篇文章主要介紹了對(duì)類Vue的MVVM前端庫(kù)的實(shí)現(xiàn)代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-09-09
  • Vue中的事件綁定與解綁方式

    Vue中的事件綁定與解綁方式

    這篇文章主要介紹了Vue中的事件綁定與解綁方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • Vue父組件調(diào)用子組件事件方法

    Vue父組件調(diào)用子組件事件方法

    下面小編就為大家分享一篇Vue父組件調(diào)用子組件事件方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-02-02
  • vue頁(yè)面批量引入組件的操作代碼

    vue頁(yè)面批量引入組件的操作代碼

    這篇文章主要介紹了vue頁(yè)面批量引入組件,本文結(jié)合示例代碼給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-12-12
  • vue2.0和mintui-infiniteScroll結(jié)合如何實(shí)現(xiàn)無(wú)線滾動(dòng)加載

    vue2.0和mintui-infiniteScroll結(jié)合如何實(shí)現(xiàn)無(wú)線滾動(dòng)加載

    這篇文章主要介紹了vue2.0和mintui-infiniteScroll結(jié)合如何實(shí)現(xiàn)無(wú)線滾動(dòng)加載,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • 簡(jiǎn)單方法實(shí)現(xiàn)Vue?無(wú)限滾動(dòng)組件示例

    簡(jiǎn)單方法實(shí)現(xiàn)Vue?無(wú)限滾動(dòng)組件示例

    這篇文章主要為大家介紹了簡(jiǎn)單方法實(shí)現(xiàn)Vue?無(wú)限滾動(dòng)組件示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • 詳解Vue3中對(duì)VDOM的改進(jìn)

    詳解Vue3中對(duì)VDOM的改進(jìn)

    這篇文章主要介紹了詳解Vue3中對(duì)VDOM的改進(jìn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • Vue項(xiàng)目如何實(shí)現(xiàn)切換主題色思路

    Vue項(xiàng)目如何實(shí)現(xiàn)切換主題色思路

    這篇文章主要介紹了Vue項(xiàng)目如何實(shí)現(xiàn)切換主題色思路,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • vue 設(shè)置 input 為不可以編輯的實(shí)現(xiàn)方法

    vue 設(shè)置 input 為不可以編輯的實(shí)現(xiàn)方法

    今天小編就為大家分享一篇vue 設(shè)置 input 為不可以編輯的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-09-09

最新評(píng)論