彻底搞懂并解决vue-cli4中图片显示的问题实现


Posted in Javascript onAugust 31, 2020

在基于 vue-cli 实际开发过程中,很多小伙伴都会遇到关于图片显示的困扰,不管怎么设置,图片就是显示不出来,今天我们来详细说说这个问题。

图片无法显示,绝大部门的情况是图片路径问题,要搞懂路径问题,分别有相对路径与绝对路径

实际开发中使用图片最多的场景有以下三种:

1、手动引入

<template>
    <img :src="imgurl" />
  </template>
  <script>
    import logo from '../img/logo.png'
    // 或
    const logo = require('../img/logo.png');
    export default{
      data(){
        return {
          imgurl:logo
        }
      }
    }
  </script>

使用require或import方式引入图片时,引入路径是相对于当前文件路径的,编译时webpack会介入并把路径处理成服务器绝路径

2、相对路径

<img src="../img/logo.png" />

vue-cli 中使用相对路径时,webpack会自动介入,上面的代码在编译时自动变成

<img src="require('../img/logo.png')"

最终在页面的显示效果与以上手动引入方式一致

3、绝对路径

<img src="/img/logo.png" />

使用绝对路径,首先要了解服务器根目录在哪,大家都知道,在 vue-cli 的项目本身自带一个服务器的,基于 webpack-dev-server 模块,根目录为 public 文件夹,所以,使用 绝对路径 的方式展示图片,必须把图片放到 public 文件夹,这也是最简单的一种方式,这种方式webpack不会介入,所以最终显示效果与引入时的代码一致,代码如下:

彻底搞懂并解决vue-cli4中图片显示的问题实现

彻底搞懂并解决vue-cli4中图片显示的问题实现

最终显示效果

彻底搞懂并解决vue-cli4中图片显示的问题实现

4、数据中的图片

<template>
    <ul>
      <li><img :src="item.imgurl" v-for="item in goodslist" /></li>
    </ul>
  </template>
  <script>
    export default{
      data(){
        return {
          goodslist:[{name:'goods1',imgurl:'../img/goods1.png'},{name:'goods2',imgurl:'../img/goods2.png'},{name:'goods3',imgurl:'../img/goods3.png'},
          ]
        }
      }
    }
  </script>

这种情况应该是最常见的(ajax请求数据回来,然后遍历写入到页面结构中),这个时候绑定到 src 属性的是一个变量,无法直接手动 importrequire ,如果直接使用 imgurl 属性中的路径, webpack不会介入处理 ,所以以上代码是无法正常显示图片的,解决方法如下:

方法1:遍历数据,使用前先手动 require

在前端,模块的引入默认是不支持动态引入的(即不支持:require(变量)),如下

this.goodslist = this.goodslist.map(item=>{
    // 虽然路径是正确的,但以下方式引入会报`Cannot find module '../assets/logo.png'`
    // item.imgurl = require(item.imgurl);

    // 正确的方式为
    item.imgurl = require('../img'+item.imgurl.replace('../img',''))
    return item;
  })

有小伙伴可能会觉得奇怪,为什么这样做就可以了,Webpack 在处理动态名称模块名的时候,会直接将能识别的静态路径和路径下的所有子文件都作为模块处理,如: require('../img'+imgName) ,能识别到 ../img 目录,并将该目录下所有文件当做模块处理,做成一个Map映射以便后面进行匹配,所以能识别到对应的文件,其原理是 require.context ,属性如下:

require.context(directory,useSubdirectories,regExp)

  • directory {String} -读取文件的路径(一般为一个目录)
  • useSubdirectories {Boolean} -是否遍历文件的子目录,默认false
  • regExp {RegExp} -匹配文件的正则,默认匹配所有文件

方法返回一个函数(假设为fn),传入图片路径(不包含directory的路径)可得到处理过的图片对应路径(如:fn('./goods1.png'),) ,上面的代码等效于

this.goodslist = this.goodslist.map(item=>{
    const fn = require.context('../img',false,/^\./);
    const file = item.replace('../img','.')
    item.imgurl = fn(file);
    return item;
  })

方法2:在数据库端直接使用绝对路径,并把所需图片放到 public 目录中

imgurl的格式为: '/img/goods1.png'

到此这篇关于彻底搞懂并解决vue-cli4中图片显示的问题实现的文章就介绍到这了,更多相关vue-cli4 图片显示 内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
jQuery-ui中自动完成实现方法
Jun 10 Javascript
用JS实现一个TreeMenu效果分享
Aug 28 Javascript
php对mongodb的扩展(小试牛刀)
Nov 11 Javascript
web的各种前端打印方法之jquery打印插件PrintArea实现网页打印
Jan 09 Javascript
JQuery中使用ajax传输超大数据的解决方法
Jul 14 Javascript
AspNet中使用JQuery boxy插件的确认框
May 20 Javascript
JS实现仿QQ面板的手风琴效果折叠菜单代码
Sep 11 Javascript
angularJS+requireJS实现controller及directive的按需加载示例
Feb 20 Javascript
如何解决vue与传统jquery插件冲突
Mar 20 Javascript
Vue中的数据监听和数据交互案例解析
Jul 12 Javascript
使用vue-cli脚手架工具搭建vue-webpack项目
Jan 14 Javascript
用Vue.js在浏览器中实现裁剪图像功能
Jun 18 Javascript
详解Node.JS模块 process
Aug 31 #Javascript
谈谈JavaScript令人迷惑的==与+
Aug 31 #Javascript
vue自定义指令限制输入框输入值的步骤与完整代码
Aug 30 #Javascript
JS性能优化实现方法及优点进行
Aug 30 #Javascript
如何检测JavaScript中的死循环示例详解
Aug 30 #Javascript
JavaScript中CreateTextFile函数
Aug 30 #Javascript
详解vue组件之间的通信
Aug 30 #Javascript
You might like
php简单操作mysql数据库的类
2015/04/16 PHP
PHP输入流php://input实例讲解
2015/12/22 PHP
详解PHP函数 strip_tags 处理字符串缺陷bug
2017/06/11 PHP
form自动提交实例讲解
2017/07/10 PHP
PHPExcel 修改已存在Excel的方法
2018/05/03 PHP
页面加载完毕后滚动条自动滚动一定位置
2014/02/20 Javascript
js获取指定日期周数以及星期几的小例子
2014/06/27 Javascript
node.js开发中使用Node Supervisor实现监测文件修改并自动重启应用
2014/11/04 Javascript
angularjs 处理多个异步请求方法汇总
2015/01/06 Javascript
jQuery实现购物车表单自动结算效果实例
2015/08/10 Javascript
jquery动态切换背景图片的简单实现方法
2016/05/14 Javascript
AngularJS ng-app 指令实例详解
2016/07/30 Javascript
javascript this详细介绍
2016/09/19 Javascript
JQuery统计input和textarea文字输入数量(代码分享)
2016/12/29 Javascript
Bootstrap modal 多弹窗之叠加引起的滚动条遮罩阴影问题
2017/02/27 Javascript
JS实现同一DOM元素上onClick事件与onDblClick事件并存的解决方法
2018/06/07 Javascript
详解Vue-axios 设置请求头问题
2018/12/06 Javascript
[42:04]DOTA2上海特级锦标赛主赛事日 - 2 胜者组第一轮#3Secret VS OG第一局
2016/03/03 DOTA
用Python编写web API的教程
2015/04/30 Python
python中numpy基础学习及进行数组和矢量计算
2017/02/12 Python
Python使用requests及BeautifulSoup构建爬虫实例代码
2018/01/24 Python
连接pandas以及数组转pandas的方法
2019/06/28 Python
python psutil监控进程实例
2019/12/17 Python
百思买美国官网:Best Buy
2016/07/28 全球购物
ZWILLING双立人英国网上商店:德国刀具锅具厨具品牌
2018/05/15 全球购物
Fanatics英国官网:美国体育电商
2018/11/06 全球购物
美国爆米花工厂:The Popcorn Factory
2019/09/14 全球购物
数据库笔试题
2013/05/09 面试题
2019年.net常见面试问题
2012/02/12 面试题
水务局局长岗位职责
2013/11/28 职场文书
优秀员工自荐书
2013/12/19 职场文书
暑假安全保证书
2015/02/28 职场文书
银行实习推荐信
2015/03/27 职场文书
市场督导岗位职责
2015/04/10 职场文书
东京审判观后感
2015/06/01 职场文书
学生会招新宣传语
2015/07/13 职场文书