前言
昨天在项目开发中遇到了一个需要展示多张图片到一个容器中的需求,每张图片在鼠标移入时都要更换图片路径,展示一个新的图片,由于每张图片大小都在2~6kb之间,webpack中配置了图片在10kb以内自动转换base64,所有就有了本篇文章的分享。先给大家展示下最后要实现的效果
实现思路
- 给每个元素添加@mouserover事件和@mouseleave事件
- 绑定函数,传用于识别当前参数的标识
- 根据所传参数判断当前状态下应该显示什么图片
解析渲染
实现过程
从json文件中读取图片信息集合,循环渲染json文件中的图片,传当前元素和当前图片的一些信息过去
<div class="row-panel"> <div class="item-panel" v-for="item in this.emojiList" :key="item.info"> <img :src="/UploadFiles/2021-04-02/${item.src}`)">引入json文件,并在data()中声明
import emoji from '../assets/json/emoji'; data() { return { emojiList:emoji, toolbarList:toolbar } }实现鼠标移入移除替换图片的函数
// 表情框鼠标悬浮显示动态表情 emojiConversion:function (event,status,path,hoverPath) { if(status==="over"){ event.target.src = require(`../assets/img/emoji/${hoverPath}`); }else{ event.target.src = require(`../assets/img/emoji/${path}`); } } emoji.json [ { "name": "pout", "src": "1fix@2x.png", "info": "撇嘴", "hover": "1@2x.gif" }, { "name": "porn", "src": "2fix@2x.png", "info": "色", "hover": "2@2x.gif" }, { "name": "smile", "src": "14fix@2x.png", "info": "微笑", "hover": "14@2x.gif" }, { "name": "smile", "src": "178fix@2x.png", "info": "滑稽", "hover": "178@2x.gif" } ]踩坑过程
错误的使用require
// 这样直接在data中写文件路径没问题,可以正常渲染 emojiSrc:{ "funny":require("../assets/img/emoji/178fix@2x.png"), "funnyNormal":require("../assets/img/emoji/178fix@2x.png"), "funnyHover":require("../assets/img/emoji/178@2x.gif"), "smile":require("../assets/img/emoji/14fix@2x.png"), "smileNormal":require("../assets/img/emoji/14fix@2x.png"), "smileHover":require("../assets/img/emoji/14@2x.gif"), "pout":require("../assets/img/emoji/1fix@2x.png"), "poutNormal":require("../assets/img/emoji/1fix@2x.png"), "poutHover":require("../assets/img/emoji/1@2x.gif"), "porn":require("../assets/img/emoji/2fix@2x.png"), "pornNormal":require("../assets/img/emoji/2fix@2x.png"), "pornHover":require("../assets/img/emoji/2@2x.gif"), }渲染结果:
但是如果在json文件中写文件的路径,渲染结果(无法识别文件路径):
解决方案:使用模板字符串,json文件只写文件名,文件路径写在当前组件
require的正确使用方式
require(`../assets/img/emoji/${hoverPath}`);总结
以上所述是小编给大家介绍的Vue实现base64编码图片间的切换功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
暂无评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
2024年11月26日
2024年11月26日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]