当前位置: 代码网 > it编程>编程语言>Javascript > Vue中图片的引用方式的区别详解

Vue中图片的引用方式的区别详解

2025年02月13日 Javascript 我要评论
前言在 vue 开发中,图片的引用方式主要取决于图片存放的位置,常见的存放方式包括:存放在 public/ 目录存放在 assets/ 目录存放在远程服务器动态拼接图片路径本文将详细分析这些方式的区别

前言

在 vue 开发中,图片的引用方式主要取决于图片存放的位置,常见的存放方式包括:

  • 存放在 public/ 目录
  • 存放在 assets/ 目录
  • 存放在远程服务器
  • 动态拼接图片路径

本文将详细分析这些方式的区别,并提供完整的代码示例和注释

1. 引用 public/ 目录

public/ 目录下的文件会被 vue 直接映射到项目的根路径 /,无需 webpack 处理,适用于:

  • 不会被打包处理的静态资源
  • 图片 url 确定,不依赖 webpack 解析

正确写法

<template>
  <div>
    <!-- 直接从 public 目录访问图片 -->
    <img src="/manufacturing.png" alt="manufacturing image" />
  </div>
</template>

错误写法

<template>
  <div>
    <!-- public 目录不需要 public/ 前缀 -->
    <img src="/public/manufacturing.png" alt="error image" />
  </div>
</template>

说明: public/ 目录的内容会被 vue 直接映射到根路径 /,所以访问 /public/xxx.png 是错误的

截图如下:

2. assets/ 目录

适用场景

assets/ 目录下的图片会被 vue 通过 webpack 进行打包,适用于:

  • 存放在 src/assets/ 目录
  • 需要 webpack 处理,如哈希命名
  • 图片路径动态变化

使用 import 方式

<script setup>
import imageurl from '@/assets/images/manufacturing.png'
</script>

<template>
  <div>
    <img :src="imageurl" alt="manufacturing image" />
  </div>
</template>

说明:

import 方式会将图片路径解析为 webpack 处理的 url

适用于静态导入,但不适用于动态路径拼接

使用 new url() 方式

<script setup>
const imagesrc = new url('@/assets/images/manufacturing.png', import.meta.url).href
</script>

<template>
  <div>
    <img :src="imagesrc" alt="manufacturing image" />
  </div>
</template>

说明:

new url() 适用于 assets 目录,支持动态路径处理

3. 远程服务器

适用场景

  • 图片存放在 cdn 或外部服务器
  • 不需要 webpack 处理
<template>
  <div>
    <img src="https://example.com/images/manufacturing.png" alt="remote image" />
  </div>
</template>

说明:

直接使用绝对 url 访问远程图片,无需 vue 处理

4. vue router 动态访问

图片名称与路由路径相关联,可以使用 computed 计算属性自动生成图片路径

<template>
  <div>
    <img :src="imagesrc" alt="dynamic page image" />
  </div>
</template>

<script setup>
import { useroute } from 'vue-router'
import { computed } from 'vue'

const route = useroute()

​​​​​​​// 计算 public 目录下的图片路径
const imagesrc = computed(() => {
  const sanitizedpath = route.path.replace(/^\//, '') // 移除开头的 `/`
  return `/${sanitizedpath}.png` // 访问 public 目录
})
</script>

假设 public 目录结构如下:

public/
├── home.png
├── about.png
├── contact.png

访问 /home 时,图片路径为:

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

动态路由的方式有所差异:

<template>
  <div>
    <img :src="imagesrc" alt="dynamic page image" />
  </div>
</template>

<script setup>
import { useroute } from 'vue-router'
import { computed } from 'vue'

const route = useroute()

​​​​​​​// 计算 public 目录下的图片路径
const imagesrc = computed(() => {
  const sanitizedpath = route.path.replace(/^\//, '') // 移除开头的 `/`
  const lastsegment = sanitizedpath.split('/').pop() // 获取最后的路径部分
  return `/${lastsegment}.png` // 访问 public 目录
})
</script>

截图如下:

5. 总结

总的来说:

存放位置适用场景访问方式代码示例
public/直接访问,无需 webpack 处理/filename.png<img src="/manufacturing.png" />
assets/需要 webpack 处理import 或 new url()import img from '@/assets/image.png'
远程服务器图片在外部服务器/cdn绝对 url<img src="https://example.com/image.png" />
动态路由根据 vue router动态生成图片路径computed 计算属性 :src=“computedpath”

最佳实践:

  • public/ 目录适用于静态资源,直接使用 /filename.png 访问
  • assets/ 目录适用于 webpack 处理,使用 import 或 new url()
  • 外部图片直接使用绝对 url
  • 动态图片路径可结合 vue router 计算生成

6. 扩展(图片不显示)

图片无法显示通常是路径错误、资源未正确加载或 webpack/vite 处理导致的问题

图片不显示的常见原因

在 vue 3 + vite(或 webpack)项目中,图片可能无法显示的常见原因包括:

1.路径错误:引用 public/ 目录时仍加 public/ 前缀

2.资源未正确加载:如 src/assets/ 目录下的图片未被 webpack 处理

3.动态路径问题:使用 computed 计算属性拼接路径时错误

4.webpack 处理方式:assets/ 目录下的图片会被 webpack 处理,不能直接访问

5.图片格式或大小问题:浏览器不支持的图片格式或图片损坏

路径错误这个要点此处着重分析下

详细分析下为何要放在public等路径下!

public/ 目录的映射机制

在 vue 项目结构中:

my-project/
├── public/
│   ├── manufacturing.png
│   ├── images/
│   │   ├── factory.png
├── src/
│   ├── views/
│   │   ├── industry.vue
│   ├── assets/
│   │   ├── example.png
│   ├── app.vue

public/manufacturing.png 在构建后会被 vue 直接映射到:/manufacturing.png

public/images/factory.png 在构建后会变成:/images/factory.png

src/assets/example.png 则会被 webpack 处理,并生成动态路径(如 /assets/example.abcdef.png)

如何证明 public/ 目录直接映射到根路径 /?

可以打开 http://localhost:5173/manufacturing.png,如果 manufacturing.png 直接显示,则说明它已经被映射到根目录 /,而不需要 /public/manufacturing.png

对比 public/ 和 src/assets/

存放目录是否被 webpack 处理访问方式适用场景
public//filename.png
src/assets/import 或 new url()

使用 public/ 目录

<template>
  <div>
    <img src="/manufacturing.png" alt="manufacturing image" />
  </div>
</template>

使用 src/assets/ 目录

<script setup>
import imgurl from '@/assets/example.png'
</script>

​​​​​​​<template>
  <div>
    <img :src="imgurl" alt="example image" />
  </div>
</template>

到此这篇关于vue中图片的引用方式的区别详解的文章就介绍到这了,更多相关vue图片引用内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com