场景
吾辈在使用 Vuetify 时突然遇到的,明明 img
标签就可以使用相对路径获取到图片,而 Veutify 的组件 v-img
却不能使用。
如下面 3 种加载图片的方式
<!-- 正常加载 --> <v-img :src="/UploadFiles/2021-04-02/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
的src
属性转换成require()
依赖。我们找到vue-loader
配置处,在options.transformToRequire
中加上v-img
即可// vuetify 框架的 src 标签也需要自动转换为 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 "_blank" href="https://vue-loader-v14.vuejs.org/zh-cn/options.html#transformtorequire" rel="external nofollow" >vue-loader 官方文档参考然后重启
npm run dev
刷新一下就行啦以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。