IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue的图片资源引入不显示问题 -> 正文阅读

[JavaScript知识库]vue的图片资源引入不显示问题

vue的图片资源引入不显示问题

问题

使用Vue框架封装组件很多适合需要引入图片这样的静态资源;为了提高复用性, 封装一个自定义vue组件,暴露 title 和 fileName 两个属性

// src/views/skills/components/Skill.vue
<template>
	<div>
		<img/>
		<p>{{ title }}</p>
	</div>
</template>

<script>
export default{
	name: 'Skill',
	props:{    
	 title: {
				type: String,
				required: false,
			},
			fileName: {
				type: String,
				required: false,
			}
	},
	methods:{
		// ...
	}
}
</script>

外部引入Skill组件,提供两个必选属性的值

  <div>
		<Skill title="Java" fileName="java.png"></Skill>
	</div>

试图获取 src/assets/logos 目录下的 java.png 文件。

最终想要完成这样的效果:

20220716170420

本文示例代码使用了 @ 符号作为根目录 /src/ 的别名

尝试无效:直接拼接

//skill组件的templates

<div elevation="2" class="skill-card">
		<img :src="getImgPath(fileName)" alt="">
		<p>{{ title }}</p>
</div>

//skill组件的methods

//skill组件的methods
getImgPath(fileName){
	const realPath = `@/assets/logos/${fileName}`
	return realPath
}

获取不到图片资源。

解决方式1:import导入静态资源

在外部引用组件前,通过import导入所有图片资源

Skill组件外写法:

<template>
	<Skill title="Node" :file="nodei"></Skill>
</template>

<script>
import nodeImg from '@/assets/logos/node.png';
export default {
	name: 'Skills',
	components: {
		Skill,
	},
	data() {
		return {
			nodei: nodeImg
		}
	},
}
</script>

这时 nodeImg 可以当做一个文件来使用,因此img标签的 src 可以直接绑定之

Skill组件内这么写:

<template>
<v-card elevation="2" class="skill-card">
<img :src="file" alt="">
<p>{{ title }}</p>
</v-card>
</template>

<script>
export default {
	name: 'SkillBlock',
	props: {
		title: {
			type: String,
			required: false,
		},
		file: {
			type: Object,
			required: false
		}
	},
</script>

最终效果:

20220716170704

解决方式2:require方法(commonjs规范)

以下方法是无效的:

//templates

<div elevation="2" class="skill-card">
		<img :src="require(getImgPath(fileName))" alt="">
		<p>{{ title }}</p>
</div>

//methods
<script>
getImgPath(fileName){
	const realPath = `@/assets/logos/${fileName}`
	return realPath
}
</script>

尽管能打印出正确的路径 @/assets/logos/java.png 但文件系统未引用到正确的静态资源;

查阅资料后得知,require通常不适用于ES6的字符串文字(模板字符串)

💫 正确的解决方法:

直接拼接字符串来向require方法中输入地址

修改 getImgPath方法为:

  getImgPath(fileName){
      let url
			try {
				url = require('@/assets/logos/' + fileName)
			} catch (error) {
				url = require('@/assets/logos/default.png') //处理一下找不到图片资源的情况
			}
			return url
}    

完成目标。

💙 如果不考虑加载失败的情况,也可以略去try…catch或者判空的步骤(getImgPath这个函数也不需要了)。以下搭配了UI框架,以Vuetify为例。

Skill组件内的template域简写为:

 <v-card elevation="2" class="skill-card">
		<v-img :src="require('@/assets/logos/' + fileName)" alt="" width="100" height="100" />
		<p>{{ title }}</p>
	</v-card>

正常加载出来的效果:

20220716170651

补充

可以用这个网站去掉png图片背景烦人的网格(alpha元素),你也不想每次都用photoshop的对吧?

Remove Background from Image - remove.bg

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-07-20 18:43:07  更:2022-07-20 18:43:18 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 12:58:34-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码