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

Vue中ElementUI結(jié)合transform使用時(shí)彈框定位不準(zhǔn)確問題解析

 更新時(shí)間:2024年01月16日 10:08:17   作者:覺醒法師  
在近期開發(fā)中,需要將1920*1080放到更大像素大屏上演示,所以需要使用到transform來對(duì)頁(yè)面進(jìn)行縮放,但是此時(shí)發(fā)現(xiàn)彈框定位出錯(cuò)問題,無(wú)法準(zhǔn)備定位到實(shí)際位置,本文給大家分享Vue中ElementUI結(jié)合transform使用時(shí)彈框定位不準(zhǔn)確解決方法,感興趣的朋友一起看看吧

在近期開發(fā)中,需要將1920*1080放到更大像素大屏上演示,所以需要使用到transform來對(duì)頁(yè)面進(jìn)行縮放,但是此時(shí)發(fā)現(xiàn)彈框定位出錯(cuò)問題,無(wú)法準(zhǔn)備定位到實(shí)際位置。

查看element-ui官方文檔無(wú)果后,打算更換新的框架進(jìn)行開發(fā),但更換幾個(gè)后發(fā)現(xiàn)都存在類似問題,由于之前項(xiàng)目都是使用element-ui,對(duì)此框架比較熟悉,所以還是決定在此基礎(chǔ)上解決問題。

在未解決前,錯(cuò)位效果如下:

如果屏幕像素更大,則偏移位置更遠(yuǎn),對(duì)此element-ui文檔中常規(guī)配置已無(wú)法解決,只能從底層考慮。

一、思路

首先,我們得在觸發(fā)日期彈框顯示前或當(dāng)時(shí),動(dòng)態(tài)修改定位相關(guān)參數(shù),在官方文檔上發(fā)現(xiàn)有focus事件,在觸發(fā)此事件時(shí),彈框開始顯示,所以在此修改相應(yīng)參數(shù)即可。

其次,綁定focus事件函數(shù),返回當(dāng)前日期組件的ref對(duì)象數(shù)據(jù),可以通過popperJS對(duì)象修改彈框的定位屬性,并使用update()函數(shù)重新更新即可。

然后,在更新完成后,需要添加setTimeout計(jì)時(shí)器,延遲修改彈框的top屬性。由于暫時(shí)未從底層了解到從哪修改top值,放在update()之前修改發(fā)現(xiàn)無(wú)效,由于內(nèi)部會(huì)重新計(jì)算覆蓋;只能在update()之后修改,出此下策也能得到同樣效果。

二、代碼

1、組件代碼

<el-date-picker
	  v-model="dateValue"
	  size="small"
	  type="date"
	  :append-to-body="false"
	  :clearable="false"
	  placeholder="選擇日期" @focus="focusFixDatePickerPosition">
	</el-date-picker>

2、輸出focus事件返回參數(shù)

methods: {
  focusFixDatePickerPosition(e){
    console.log(e);
  }
}

輸出結(jié)果如下:

3、經(jīng)測(cè)試,發(fā)現(xiàn)同update()函數(shù)一樣效果的函數(shù)還有很多,如下:

// popperJS.state中updateBound()調(diào)用也會(huì)重新更新彈框位置
e.popperJS.state.updateBound();
// 直接調(diào)用popperJS中的update()
e.popperJS.update();
// 使用showPicker()也有同樣效果
e.showPicker();
// 使用updatePopper(),也會(huì)更新彈框位置
e.updatePopper();

在實(shí)際開發(fā)中,根據(jù)需要使用其中一個(gè)即可。每個(gè)函數(shù)本人也沒作研究,只是測(cè)試發(fā)現(xiàn)可實(shí)現(xiàn)同樣效果,喜歡鉆牛角尖的同學(xué)可以研究下。

4、在methods中定義focusFixDatePickerPosition函數(shù)

methods: {
  focusFixDatePickerPosition(e){
	this.$nextTick(() => {
	  // 修改定位屬性,將fixed改成absolute
	  e.popperJS.state.position = 'absolute';
	  // 調(diào)用update()后,彈框位置重新調(diào)休
	  e.popperJS.update();
      // 添加計(jì)時(shí)器
	  setTimeout(() => {
		// 輸入框高度為彈框 頂部偏移量,獲取后賦值給top即可
		e.picker.$el.style.top = e.$el.clientHeight + "px";
	  }, 20);
	});
  }
}

此時(shí),則完成了彈框位置的修正,效果如下:

到此這篇關(guān)于Vue中ElementUI結(jié)合transform使用時(shí),發(fā)現(xiàn)彈框定位不準(zhǔn)確問題的文章就介紹到這了,更多相關(guān)vue ElementUI彈框定位不準(zhǔn)確內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue?Token過期問題的2種解決方案小結(jié)

    Vue?Token過期問題的2種解決方案小結(jié)

    在使用token進(jìn)行登錄的過程中,如果token過期了,需要重新輸入用戶名和密碼登錄,這種體驗(yàn)肯定是不好的,下面這篇文章主要給大家介紹了關(guān)于Vue?Token過期問題的2種解決方案,需要的朋友可以參考下
    2023-02-02
  • 一文詳解Vue3中的自定義指令的使用

    一文詳解Vue3中的自定義指令的使用

    自定義指令是?Vue.js?中一個(gè)強(qiáng)大的特性,它允許您擴(kuò)展?Vue?的模板語(yǔ)法,本文將詳細(xì)介紹?Vue?3?中的自定義指令,包括如何創(chuàng)建它們以及如何將它們應(yīng)用于您的應(yīng)用程序,需要的可以參考下
    2023-11-11
  • VUE開發(fā)一個(gè)圖片輪播的組件示例代碼

    VUE開發(fā)一個(gè)圖片輪播的組件示例代碼

    本篇文章主要介紹了VUE開發(fā)一個(gè)圖片輪播的組件示例代碼,對(duì)圖片輪播效果感興趣的小伙伴們可以參考一下。
    2017-03-03
  • 如何修改ant?design組件自帶樣式

    如何修改ant?design組件自帶樣式

    這篇文章主要介紹了如何修改ant?design組件自帶樣式問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • 一篇文章帶你了解vue.js的事件循環(huán)機(jī)制

    一篇文章帶你了解vue.js的事件循環(huán)機(jī)制

    這篇文章主要為大家詳細(xì)介紹了vue.js事件循環(huán)機(jī)制,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • vue腳手架項(xiàng)目創(chuàng)建步驟詳解

    vue腳手架項(xiàng)目創(chuàng)建步驟詳解

    這篇文章主要介紹了vue腳手架項(xiàng)目創(chuàng)建步驟詳解,文章講解的很清晰,初學(xué)者可以跟著步驟學(xué)習(xí)下
    2021-03-03
  • vue實(shí)現(xiàn)滑塊拖拽校驗(yàn)功能的全過程

    vue實(shí)現(xiàn)滑塊拖拽校驗(yàn)功能的全過程

    vue驗(yàn)證滑塊功能,在生活中很多地方都可以見到,使用起來非常方便,這篇文章主要給大家介紹了關(guān)于vue實(shí)現(xiàn)滑塊拖拽校驗(yàn)功能的相關(guān)資料,需要的朋友可以參考下
    2021-08-08
  • Vue源碼探究之狀態(tài)初始化

    Vue源碼探究之狀態(tài)初始化

    這篇文章主要介紹了Vue源碼探究之狀態(tài)初始化,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-11-11
  • Vue中跨標(biāo)簽通信詳解

    Vue中跨標(biāo)簽通信詳解

    這篇文章主要為大家詳細(xì)介紹了介紹了Vue中跨標(biāo)簽通信的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-01-01
  • vue-cli如何快速構(gòu)建vue項(xiàng)目

    vue-cli如何快速構(gòu)建vue項(xiàng)目

    本篇文章主要介紹了vue-cli如何快速構(gòu)建vue項(xiàng)目,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-04-04

最新評(píng)論