在Vue 3中加载本地图片和其他静态资源

在Vue 3中加载本地图片和其他静态资源有几种方法:

一、使用绝对路径:

将图片放在public目录下,然后使用绝对路径来引用它们。

例如,如果图片位于public/images/logo.png,可以在组件中使用 :

html 复制代码
<img src="/images/logo.png">

来加载它。

但是请注意:public目录下,图片不经过编译。

二、使用相对路径:

如果图片和组件位于同一目录下,可以在模板中直接使用相对路径来引用本地图片和其他静态资源。

例如,如果图片位于与组件相同的目录下,可以使用

html 复制代码
<img src="./logo.png">

来加载它。

三、使用require导入:

Vue 3中,你可以使用require函数将图片作为模块导入,然后在组件中使用它。

首先,确保你已经安装了file-loader或url-loader插件。然后,在组件中使用以下代码:

html 复制代码
<template>
  <div>
    <img :src="imageSrc" alt="My Image">
  </div>
</template>

<script>
import myImage from '@/assets/logo.png'; // 替换成你的图片路径

export default {
  data() {
    return {
      imageSrc: ''
    };
  },
  mounted() {
    this.imageSrc = require(`@/assets/logo.png`);
  }
};
</script>

也可以这样直接使用require函数来引用本地图片和其他静态资源。例如:

html 复制代码
<img :src="require('./assets/logo.png')">

在这个例子中,require('./assets/logo.png')将会返回一个包装了图片路径的模块路径。注意,使用require函数需要在vue.config.js中进行配置。

四、使用import导入:

如果你使用了Webpack等构建工具,也可以使用ES6的import语法来导入图片。

首先,确保你已经安装了file-loader或url-loader插件。然后,在组件中使用以下代码:

html 复制代码
<template>
  <div>
    <img :src="imageSrc" alt="My Image">
  </div>
</template>

<script>
import myImage from '@/assets/logo.png'; // 替换成你的图片路径

export default {
  data() {
    return {
      imageSrc: ''
    };
  },
  mounted() {
    import(`@/assets/logo.png`).then((src) => {
        this.imageSrc = src.default;
    });
  }
};
</script>

以上是几种加载本地图片和其他静态资源的方法,根据你的具体需求和项目配置选择适合的方法即可。

相关推荐
蚂蚁集团数据体验技术16 分钟前
一个可以补充 Mermaid 的可视化组件库 Infographic
前端·javascript·llm
LQW_home25 分钟前
前端展示 接受springboot Flux数据demo
前端·css·css3
q***d17331 分钟前
前端增强现实案例
前端·ar
IT_陈寒32 分钟前
Vite 3.0 重磅升级:5个你必须掌握的优化技巧和实战应用
前端·人工智能·后端
JarvanMo37 分钟前
Flutter 3.38 + Firebase:2025 年开发者必看的新变化
前端
Lethehong1 小时前
简历优化大师:基于React与AI技术的智能简历优化系统开发实践
前端·人工智能·react.js·kimi k2·蓝耘元生代·蓝耘maas
华仔啊1 小时前
还在用 WebSocket 做实时通信?SSE 可能更简单
前端·javascript
鹏北海1 小时前
多标签页登录状态同步:一个简单而有效的解决方案
前端·面试·架构
_AaronWong1 小时前
基于 Vue 3 的屏幕音频捕获实现:从原理到实践
前端·vue.js·音视频开发
孟祥_成都1 小时前
深入 Nestjs 底层概念(1):依赖注入和面向切面编程 AOP
前端·node.js·nestjs