vue 打包静态 img 图片路径问题

最近在写一个后台系统项目,有一个选择功能是以图片为背景的,就想提炼出一个组件公用;但在img动态绑定的时候出现了问题,在本地运行时img是正常显示的,但build打包后就不行,img显示不;
通过分析发现build后的img是通过静态资源转码的,也就是在img的后面加上hash值,且是按需加载的,但HTML的img是动态生成的,所以在build的后的img是没有hash值的;
原代码如下:
HTML部分

    <dd>
          <div v-bind:class="[currentgame[0]['typegame'] == Active?'activeImg':'']" @click="addActive(currentgame[0]['typegame'])">
           <img :img=" '../../../../static/images/'+currentgame[0]['typegame']+'png' "  alt="">
            <p>
              <i class="fa fa-check-circle-o"></i>
            </p>
          </div>
          <span>{{currentgame[0]['name']}}</span>
     </dd>

js部分:

<script>
export default{
    data(){
        return{
      Active:'',
      activeContent:
      [
        [
            {
                "typegame": "cat",
                "name": "小猫钓鱼"
            }
    ]
  ]
</script>

这时,本地运行时没问题的,但build后报错;
对代码进行改进;
HTML部分:

      <dd>
          <div v-bind:class="[currentgame[0]['typegame'] == Active?'activeImg':'']" @click="addActive(currentgame[0]['typegame'])">
           <img :img=" currentgame[0]['img']"  alt="">
            <p>
              <i class="fa fa-check-circle-o"></i>
            </p>
          </div>
          <span>{{currentgame[0]['name']}}</span>
       </dd>

js部分,这时就需要用到 require引入文件

<script>
const cat = require('../../../../static/images/cat.png');
export default{
    data(){
        return{
      Active:'',
      activeContent:
      [
        [
            {
                "typegame": "cat",
                "name": "小猫钓鱼",
                "img":cat
            }
    ]
  ]
</script>

这时本地img将会加上hash值,img已经被引用,build后的img就是原来require时的;
主意此时的activeContent数据中增加了“img”对象,以便:img引用,如果用“typegame”则不会寻找img的url,仅仅会显示“cat”;
以上代码仅为示例部分代码;

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,510评论 11 349
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,174评论 19 139
  • 写在开头 先说说为什么要写这篇文章, 最初的原因是组里的小朋友们看了webpack文档后, 表情都是这样的: (摘...
    Lefter阅读 10,711评论 4 31
  • 无意中看到zhangwnag大佬分享的webpack教程感觉受益匪浅,特此分享以备自己日后查看,也希望更多的人看到...
    小小字符阅读 12,560评论 7 35
  • 被一个朋友问到什么是“情商”,我说情商是情绪的掌控,能控制好情绪的人情商是高的,世间所有人物关系都会...
    茶蘼半暖阅读 1,630评论 0 2

友情链接更多精彩内容