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

Vue中ElementUI結合transform使用時彈框定位不準確問題解析

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

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

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

在未解決前,錯位效果如下:

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

一、思路

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

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

然后,在更新完成后,需要添加setTimeout計時器,延遲修改彈框的top屬性。由于暫時未從底層了解到從哪修改top值,放在update()之前修改發(fā)現(xiàn)無效,由于內(nèi)部會重新計算覆蓋;只能在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);
  }
}

輸出結果如下:

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

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

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

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

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

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

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

相關文章

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    Vue中跨標簽通信詳解

    這篇文章主要為大家詳細介紹了介紹了Vue中跨標簽通信的相關知識,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2024-01-01
  • vue-cli如何快速構建vue項目

    vue-cli如何快速構建vue項目

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

最新評論