亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue中獲取圖片高度的兩種方法

 更新時(shí)間:2024年08月01日 09:28:10   作者:一溪風(fēng)月  
在使用Vue2開發(fā)移動(dòng)端頁面的時(shí)候,需要做一個(gè)效果,實(shí)現(xiàn)的方案是背景漸變,但是想要實(shí)現(xiàn)這個(gè)效果就必須進(jìn)行定位,我的背景高度需要在一個(gè)十分恰當(dāng)?shù)奈恢?但是我的圖片會(huì)隨著移動(dòng)端頁面的變化而發(fā)生高度的變化,為什么會(huì)變化?所以本文介紹了Vue中獲取圖片高度的方法

一.問題描述

在使用Vue2開發(fā)移動(dòng)端頁面的時(shí)候,需要做一個(gè)效果,實(shí)現(xiàn)的方案是背景漸變,但是想要實(shí)現(xiàn)這個(gè)效果就必須進(jìn)行定位,然后設(shè)置z-index讓這個(gè)元素在其他元素的下面,我的背景高度需要在一個(gè)十分恰當(dāng)?shù)奈恢茫谶@個(gè)背景上面還有另外一張圖片,但是我的圖片會(huì)隨著移動(dòng)端頁面的變化而發(fā)生高度的變化,為什么會(huì)變化哪?因?yàn)槲以O(shè)置了圖片的寬度為100%這樣就有可能導(dǎo)致,背景的位置在寬屏的情況下和UI差距比較大,所以我需要獲取圖片的高度,然后在這個(gè)高度上增加合適的高度就可以在任何屏幕中自適應(yīng),但是無論我在mounted中如何獲取,甚至在$nextTick中獲取到的圖片高度都是0,導(dǎo)致一直無法實(shí)現(xiàn)自己想要的效果,以上描述的效果基本如下:

二.問題分析

出現(xiàn)這個(gè)問題的點(diǎn)在于,進(jìn)行背景設(shè)置的元素,是定位的,所以脫離了標(biāo)準(zhǔn)流,導(dǎo)致它的高度無法被撐起來,并且也不能撐起來,因?yàn)樗母叨仁且粋€(gè)比較特殊的高度,所以只能進(jìn)行定位,但是又因?yàn)閳D片的高度變化,導(dǎo)致背景一個(gè)固定的值不能滿足要求,解決方案是動(dòng)態(tài)獲取圖片的高度然后相應(yīng)的去設(shè)置背景元素的高度,比較坑的地方就在于直接在mounted$nextTick中拿不到高度,原因在于圖片未加載完成,所以需要在圖片完全加載后進(jìn)行后續(xù)的處理。

三.問題解決

解決方案一: 使用JS的方式進(jìn)行獲取圖片高度,在圖片高度的基礎(chǔ)上動(dòng)態(tài)設(shè)置背景高度。

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);
  },

解決這個(gè)問題的方法就是使用 @load="handleImageLoad"當(dāng)圖片加載完畢之后就會(huì)直接出發(fā)這個(gè)方法中的邏輯進(jìn)行處理,然后獲取高度來讓背景跟隨圖片高度進(jìn)行變化。

解決方案二: 手動(dòng)計(jì)算圖片比例,使用vw進(jìn)行動(dòng)態(tài)計(jì)算。

.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;
}

四.問題總結(jié)

這個(gè)問題其實(shí)本質(zhì)原因還是對不同內(nèi)容加載完成時(shí)機(jī)不夠清楚,因?yàn)樵陂_發(fā)過程中有時(shí)候確實(shí)不太會(huì)去考慮拿到圖片的高度,但是其實(shí)使用vw來解決這個(gè)問題其實(shí)是更好的,它的缺點(diǎn)在于需要自己去計(jì)算寬高比,但是本著不寫代碼就不會(huì)有bug的原則,能夠盡量使用純CSS解決的問題就用純CSS來解決。

到此這篇關(guān)于Vue中獲取圖片高度的兩種方法的文章就介紹到這了,更多相關(guān)Vue中獲取圖片高度內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue如何解決echarts升級后本地?zé)o法啟動(dòng)的問題

    vue如何解決echarts升級后本地?zé)o法啟動(dòng)的問題

    這篇文章主要介紹了vue如何解決echarts升級后本地?zé)o法啟動(dòng)的問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • Vue使用高德地圖選點(diǎn)定位搜索定位功能實(shí)現(xiàn)

    Vue使用高德地圖選點(diǎn)定位搜索定位功能實(shí)現(xiàn)

    這篇文章主要介紹了Vue使用高德地圖選點(diǎn)定位搜索定位功能,文中給大家提到了常見問題解決方法,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-10-10
  • Vue使用預(yù)渲染代替SSR的方法

    Vue使用預(yù)渲染代替SSR的方法

    這篇文章主要介紹了Vue使用預(yù)渲染代替SSR的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • 十分鐘帶你快速上手Vue3過渡動(dòng)畫

    十分鐘帶你快速上手Vue3過渡動(dòng)畫

    在開發(fā)中我們想要給一個(gè)組件的顯示和消失添加某種過渡動(dòng)畫,可以很好的增加用戶體驗(yàn),下面這篇文章主要給大家介紹了關(guān)于如何快速上手Vue3過渡動(dòng)畫的相關(guān)資料,需要的朋友可以參考下
    2022-02-02
  • Vue3+Vite項(xiàng)目使用less的實(shí)現(xiàn)步驟

    Vue3+Vite項(xiàng)目使用less的實(shí)現(xiàn)步驟

    最近學(xué)習(xí)在vite項(xiàng)目中配置less,本文主要介紹了Vue3+Vite項(xiàng)目使用less的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-02-02
  • vue踩坑日記之params傳遞參數(shù)問題

    vue踩坑日記之params傳遞參數(shù)問題

    這篇文章主要介紹了vue踩坑日記之params傳遞參數(shù)問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • Vue3之使用js實(shí)現(xiàn)動(dòng)畫示例解析

    Vue3之使用js實(shí)現(xiàn)動(dòng)畫示例解析

    這篇文章主要為大家介紹了Vue3之使用js實(shí)現(xiàn)動(dòng)畫示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • 關(guān)于Vite不能使用require問題的解決方法

    關(guān)于Vite不能使用require問題的解決方法

    在vue2中我們通常會(huì)在模板中通過三目運(yùn)算符和require來實(shí)現(xiàn)動(dòng)態(tài)圖片,下面這篇文章主要給大家介紹了關(guān)于Vite不能使用require問題的解決方法,需要的朋友可以參考下
    2022-10-10
  • vue2過濾器模糊查詢方法

    vue2過濾器模糊查詢方法

    今天小編就為大家分享一篇vue2過濾器模糊查詢方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vue實(shí)現(xiàn)ToDoList簡單實(shí)例

    vue實(shí)現(xiàn)ToDoList簡單實(shí)例

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)ToDoList簡單實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-02-02

最新評論