您当前的位置:首页 > 网站建设 > javascript
| php | asp | css | H5 | javascript | Mysql | Dreamweaver | Delphi | 网站维护 | 帝国cms | React | 考试系统 | ajax |

v-for循环中使用require/import关键字引入本地图片的几种方式

51自学网 2022-05-02 21:32:47
  javascript

问题描述

我们做项目中,常常需要把图片呈现到页面上,一般来说有以下几种方式

方式一(后端返回图片URL)

这种方式就是后端返回图片的url地址,我们直接img标签的src属性绑定imgUrl即可。如下代码:

<div class="item" v-for="(item, index) in apiArr" :key="index">    <!-- apiArr是后端返回的数据,其中的每一项中都有一个imgUrl属性,存储的是图片的url地址 -->    <img :src="item.imgUrl" alt=""></div>

方式二(前端使用require)

第二种方式,把图片文件存储到前端里,后端只返回图片的名字(或不返回图片数据),代码举例如下:

代码附上

<template>  <div class="wrap">    <div class="item" v-for="(item, index) in apiArr" :key="index">      <div class="imgWrap">        <!-- require引入图片文件模块 -->        <img :src="require(`@/assets/img/${item.imgTitle}.png`)" alt="" />        <!-- 最后就变成这样的了就能正常显示了 <img src="@/assets/img/first.png" alt=""> -->      </div>      <div class="infoWrap">        <div><span class="bloder">名次:</span> {{ item.title }}</div>        <div><span class="bloder">得分:</span> {{ item.score }}</div>      </div>    </div>      </div></template><script>export default {  data() {    return {      apiArr: [],    };  },  mounted() {    // 假设apiArr是我们发请求后端返回的数据,里面的imgTitle属性存储的是图片的名字    // 通过require关键字引入,会自动到指定路径下的文件中寻找对应的图片文件加载出来    this.apiArr = [      {        title: "冠军",        score: "98.8",        imgTitle: "first",      },      {        title: "亚军",        score: "97.9",        imgTitle: "second",      },      {        title: "季军",        score: "96.2",        imgTitle: "third",      },    ];  },};</script>

效果图如下

项目文件结构图

方式三(前端使用import)

代码附上

<template>  <div class="wrap">    <div class="item" v-for="(item, index) in apiArr" :key="index">      <div class="imgWrap">        <img :src="item.imgTitle" alt="" />      </div>      <div class="infoWrap">        <div><span class="bloder">名次:</span> {{ item.title }}</div>        <div><span class="bloder">得分:</span> {{ item.score }}</div>      </div>    </div>  </div></template><script>// import 引入图片import first from "@/assets/img/first.png";import second from "@/assets/img/second.png";import third from '@/assets/img/third.png'export default {  data() {    return {      apiArr: [        {          title: "冠军",          score: "98.8",          imgTitle: first, // 使用引入的图片        },        {          title: "亚军",          score: "97.9",          imgTitle: second, // 使用引入的图片        },        {          title: "季军",          score: "96.2",          imgTitle: third, // 使用引入的图片        },      ],    };  },};</script>

效果图和项目文件结构图同上,这里不赘述

总结

ES6中import方式引入,和commonjs中require方式引入图片都可以,不过我个人更加推荐使用require方式,因为略为灵活点

到此这篇关于v-for循环中使用require/import关键字引入本地图片的文章就介绍到这了,更多相关v-for引入本地图片内容请搜索wanshiok.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持wanshiok.com!


Vue.js中让人容易忽略的API详解
面向JavaScript入门初学者的二叉搜索树算法教程
51自学网,即我要自学网,自学EXCEL、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。
京ICP备13026421号-1