Vue中获取图片高度问题及解决

一.问题描述


在使用Vue2开发移动端页面的时候,需要做一个效果,实现的方案是背景渐变,但是想要实现这个效果就必须进行定位,然后设置z-index让这个元素在其他元素的下面,我的背景高度需要在一个十分恰当的位置,在这个背景上面还有另外一张图片,但是我的图片会随着移动端页面的变化而发生高度的变化,为什么会变化哪?因为我设置了图片的宽度为100%这样就有可能导致,背景的位置在宽屏的情况下和UI差距比较大,所以我需要获取图片的高度,然后在这个高度上增加合适的高度就可以在任何屏幕中自适应,但是无论我在mounted中如何获取,甚至在$nextTick中获取到的图片高度都是0,导致一直无法实现自己想要的效果,以上描述的效果基本如下:

二.问题分析


出现这个问题的点在于,进行背景设置的元素,是定位的,所以脱离了标准流,导致它的高度无法被撑起来,并且也不能撑起来,因为它的高度是一个比较特殊的高度,所以只能进行定位,但是又因为图片的高度变化,导致背景一个固定的值不能满足要求,解决方案是动态获取图片的高度然后相应的去设置背景元素的高度,比较坑的地方就在于直接在mounted$nextTick中拿不到高度,原因在于图片未加载完成,所以需要在图片完全加载后进行后续的处理。

三.问题解决


解决方案一: 使用JS的方式进行获取图片高度,在图片高度的基础上动态设置背景高度。

js 复制代码
methods: {
  handleImageLoad(event) {
    const height = event.target.offsetHeight;
    this.height1 = height + 120;
  },

  getPicHeight() {
    this.height1 = this.$refs.myPictrue.offsetHeight + 120;
  },
},

  mounted() {
    window.addEventListener("resize", () => {
      this.getPicHeight();
    });
  },

  beforeDestroy() {
    window.removeEventListener("resize", this.getPicHeight);
  },

解决这个问题的方法就是使用 @load="handleImageLoad"当图片加载完毕之后就会直接出发这个方法中的逻辑进行处理,然后获取高度来让背景跟随图片高度进行变化。


解决方案二: 手动计算图片比例,使用vw进行动态计算。

css 复制代码
.img {
  width: 100vw;
  height: 40vw;
  position: relative;
  z-index: 9;
  background-color: red;
}
.img-bg {
  width: 100vw;
  position: absolute;
  top: 0;
  left: 0;
  height: calc(40vw + 120px);
  background-color: green;
}

四.问题总结


这个问题其实本质原因还是对不同内容加载完成时机不够清楚,因为在开发过程中有时候确实不太会去考虑拿到图片的高度,但是其实使用vw来解决这个问题其实是更好的,它的缺点在于需要自己去计算宽高比,但是本着不写代码就不会有bug的原则,能够尽量使用纯CSS解决的问题就用纯CSS来解决。

相关推荐
blackorbird1 小时前
Edge 浏览器 IE 模式成攻击突破口:黑客借仿冒网站诱导攻击
前端·edge
谷歌开发者2 小时前
Web 开发指向标 | Chrome 开发者工具学习资源 (一)
前端·chrome·学习
名字越长技术越强2 小时前
Chrome和IE获取本机ip地址
前端
天***88962 小时前
Chrome 安装失败且提示“无可用的更新” 或 “与服务器的连接意外终止”,Chrome 离线版下载安装教程
前端·chrome
半梦半醒*2 小时前
zabbix安装
linux·运维·前端·网络·zabbix
清羽_ls3 小时前
React Hooks 核心规则&自定义 Hooks
前端·react.js·hooks
你的人类朋友3 小时前
“签名”这个概念是非对称加密独有的吗?
前端·后端·安全
西陵3 小时前
Nx带来极致的前端开发体验——任务缓存
前端·javascript·架构
10年前端老司机4 小时前
Promise 常见面试题(持续更新中)
前端·javascript
潘小安5 小时前
跟着 AI 学 (一)- shell 脚本
前端·ci/cd·vibecoding