欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

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

一.問題描述

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

二.問題分析

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

三.問題解決

解決方案一: 使用JS的方式進(jìn)行獲取圖片高度,在圖片高度的基礎(chǔ)上動態(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);
  },

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

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

.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é)

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

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

相關(guān)文章

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

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

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

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

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

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

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

    十分鐘帶你快速上手Vue3過渡動畫

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

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

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

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

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

    Vue3之使用js實現(xiàn)動畫示例解析

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

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

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

    vue2過濾器模糊查詢方法

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

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

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

最新評論