彻底搞懂并解决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 相关文章推荐
彻底搞懂JS无缝滚动代码
Jan 03 Javascript
jquery自动切换tabs选项卡的具体实现
Dec 24 Javascript
基于jQuery实现的菜单切换效果
Oct 16 Javascript
用director.js实现前端路由使用实例
Jan 27 Javascript
canvas仿iwatch时钟效果
Mar 06 Javascript
js按条件生成随机json:randomjson实现方法
Apr 07 Javascript
Webpack框架核心概念(知识点整理)
Dec 22 Javascript
详解ES6语法之可迭代协议和迭代器协议
Jan 13 Javascript
解决angular双向绑定无效果,ng-model不能正常显示的问题
Oct 02 Javascript
vue 解决文本框被键盘遮住的问题
Nov 06 Javascript
JavaScript语句错误throw、try及catch实例解析
Aug 18 Javascript
vue+echarts实现动态折线图的方法与注意
Sep 01 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常用的小程序代码段
2015/11/14 PHP
讲解WordPress中用于获取评论模板和搜索表单的PHP函数
2015/12/28 PHP
PHP Try-catch 语句使用技巧
2016/02/28 PHP
图片自动更新(说明)
2006/10/02 Javascript
jquery简单体验
2007/01/10 Javascript
jquery 分页控件实现代码
2009/11/30 Javascript
利用javascript打开模态对话框(示例代码)
2014/01/11 Javascript
详解JavaScript中getFullYear()方法的使用
2015/06/10 Javascript
jQuery简单实现input文本框内灰色提示文本效果的方法
2015/12/02 Javascript
jQuery图片轮播插件——前端开发必看
2016/05/31 Javascript
深入理解Angularjs向指令传递数据双向绑定机制
2016/12/31 Javascript
webstorm和.vue中es6语法报错的解决方法
2018/05/08 Javascript
Vue-cli配置打包文件本地使用的教程图解
2018/08/02 Javascript
AngularJS自定义表单验证功能实例详解
2018/08/24 Javascript
mpvue中使用flyjs全局拦截的实现代码
2018/09/13 Javascript
vue基础之事件简写、事件对象、冒泡、默认行为、键盘事件实例分析
2019/03/11 Javascript
vue项目部署到nginx/tomcat服务器的实现
2019/08/26 Javascript
vue中watch和computed为什么能监听到数据的改变以及不同之处
2019/12/27 Javascript
图解JS原型和原型链实现原理
2020/09/15 Javascript
[02:51]DOTA2 Supermajor小组分组对阵抽签仪式
2018/06/01 DOTA
python操作 hbase 数据的方法
2016/12/18 Python
Python使用当前时间、随机数产生一个唯一数字的方法
2017/09/18 Python
Python针对给定字符串求解所有子序列是否为回文序列的方法
2018/04/21 Python
Python3中列表list合并的四种方法
2019/04/19 Python
用Q-learning算法实现自动走迷宫机器人的方法示例
2019/06/03 Python
python和pywin32实现窗口查找、遍历和点击的示例代码
2020/04/01 Python
Sephora丝芙兰泰国官方网站:国际知名化妆品购物
2017/11/15 全球购物
哈曼俄罗斯官方网上商店:Harman.club
2020/07/24 全球购物
澳洲的UGG雪地靴超级市场:Uggs.com.au
2020/04/06 全球购物
如何选择使用结构还是类
2014/05/30 面试题
招商银行工作证明
2015/06/17 职场文书
学习杨善洲同志先进事迹心得体会
2016/01/23 职场文书
学生早退检讨书(范文)
2019/08/19 职场文书
导游词之苏州盘门景区
2019/11/12 职场文书
深入理解redis中multi与pipeline
2021/06/02 Redis
python标准库ElementTree处理xml
2022/05/20 Python