vue中解決拖拽改變存在iframe的div大小時(shí)卡頓問(wèn)題
寫(xiě)在最前
針對(duì)于在vue中實(shí)現(xiàn)拖拽改變兩左右個(gè)div大小的方式,請(qǐng)查看上一篇文章《vue中實(shí)現(xiàn)拖動(dòng)調(diào)整左右兩側(cè)div的寬度》。此文章主要針對(duì)于實(shí)際應(yīng)用中需要拖拽改變大小的組件中使用iframe框架時(shí)存在明顯卡頓的問(wèn)題,比如這樣,右側(cè)div中使用了一個(gè)iframe組件,導(dǎo)致實(shí)際操作中出現(xiàn)兩個(gè)問(wèn)題,一個(gè)是拖不動(dòng),另外一個(gè)是無(wú)法根據(jù)鼠標(biāo)移動(dòng),快速響應(yīng),甚至在監(jiān)聽(tīng)鼠標(biāo)的按下和松開(kāi)事件上都有明顯的卡頓問(wèn)題。如果去除右側(cè)iframe框架,則沒(méi)有問(wèn)題。
有iframe情況
無(wú)iframe情況
問(wèn)題原因&解決思路
問(wèn)題原因我不知道,不過(guò)這個(gè)博客給了我解決思路《解決jqueryUI的拖拽,如果元素中含有iframe,拖動(dòng)卡的問(wèn)題》,還有以下說(shuō)法,他們的解決思路一樣的。因此我猜想是鼠標(biāo)的監(jiān)聽(tīng)造成的影響,在我們拖拽的時(shí)候,因?yàn)橥献н^(guò)快,很容易出現(xiàn)鼠標(biāo)移動(dòng)超過(guò)拖拽范圍的情況,此時(shí)的鼠標(biāo)可能已經(jīng)在iframe上方,從而會(huì)同時(shí)加載iframe中的內(nèi)容,導(dǎo)致出現(xiàn)卡頓。
總之,解決的思路就是在拖動(dòng)的時(shí)候,在iframe上方添加一個(gè)透明的遮罩層,然后在停止拖拽的時(shí)候讓其消失。這樣問(wèn)題就可以完美解決了。
解決方式共有兩節(jié),一節(jié)包含我解決過(guò)程中遇到的問(wèn)題,一節(jié)是直接的解決方式,如果想直接查看解決方式的,請(qǐng)直接跳轉(zhuǎn)至解決方式那一節(jié)
解決方式(含解決過(guò)程中遇到的問(wèn)題)
HTML組件部分源代碼
這是實(shí)現(xiàn)拖拽的組件代碼,如果不了解我原本使用的實(shí)現(xiàn)方式,請(qǐng)參考《vue中實(shí)現(xiàn)拖動(dòng)調(diào)整左右兩側(cè)div的寬度》
<div ref='box'> <div ref='left'> </div> <div ref='resize'> ⋮ </div> <div ref='mid'> <!--在此處添加遮罩層--> <iframe name='iFrame1' frameborder='0' scrolling='auto' :src='http://www.aoyou183.cn/bcjs/iframeUrl'> </iframe> </div> </div>
添加遮罩層
在以上標(biāo)注的地方,添加如下代碼
<div class='iframeDiv'></div>
再添加遮罩層的css樣式即可,此時(shí)最好測(cè)試點(diǎn)擊一下,是不是原來(lái)的ifame部分已經(jīng)不能點(diǎn)擊,而且拖拽起來(lái)已經(jīng)不再卡頓了
/* 添加透明遮罩層 */ .iframeDiv { width: 100%; height: 100%; position: absolute; z-index: 1111; filter: alpha(opacity=0); opacity: 0; background: transparent; margin-top: 30px; /*display: none;*/ }
實(shí)現(xiàn)遮罩層在拖拽時(shí)出現(xiàn)
我的解決辦法是直接在拖拽區(qū)域添加監(jiān)聽(tīng)鼠標(biāo)的按下和松開(kāi)事件,按下后遮罩層出現(xiàn),松開(kāi)后消失,因此修改resize部分,添加onmouseup&mousedown,分別傳入?yún)?shù),用于修改iframeDiv的css樣式中的display屬性值
<div ref='resize' @mousedown='changeIframeDivStyle(’’)' @onmouseup='changeIframeDivStyle(’none’)' >⋮ </div>
然后添加changeIframeDivStyle方法,因?yàn)間etElementByClassName返回的是個(gè)數(shù)組集合,但是我又確認(rèn)自己頁(yè)面只有一個(gè)iframeDiv,所以選擇了iframe[0],如果想使用getElementById也可以
changeIframeDivStyle(display) { var iframeDiv = document.getElementsByClassName(’iframeDiv’); iframeDiv[0].style.display = display; },
到此基本就算完成大半了,mousedown為鼠標(biāo)按下事件,按下后設(shè)置display為空,即遮罩層出現(xiàn),onmouseup為鼠標(biāo)松開(kāi)事件,松開(kāi)后遮罩層消失,達(dá)到不影響用戶(hù)操作查看iframe中內(nèi)容的目的
頁(yè)面初始化時(shí)遮罩層設(shè)置問(wèn)題
按照實(shí)際來(lái)講,初始化進(jìn)入頁(yè)面時(shí),我們就不應(yīng)該留有遮罩層,所以按照我的想法來(lái)講,就是直接在css中修改樣式,但是如上所見(jiàn),我把它注釋掉了,至于為什么,先賣(mài)個(gè)關(guān)子,大家修改后嘗試一下,看看拖拽時(shí)卡頓不卡頓
display: none;
在我本以為這樣就可以解決問(wèn)題時(shí),我發(fā)現(xiàn),首次進(jìn)入頁(yè)面,直接進(jìn)行拖拽,依舊會(huì)存在卡頓,但是拖拽過(guò)一次之后,就不會(huì)再有問(wèn)題了。這個(gè)問(wèn)題,,我又不知道為什么了,于是,既然它需要拖拽一次之后才不會(huì)卡頓,那我就直接注釋掉了css中這個(gè)display樣式,反而在 mounted中添加方法,這樣反而成功了,雖然搞不明白兩者的差距,但是問(wèn)題總算是解決了,如果有知道原因的朋友,可以在評(píng)論中分享出來(lái),供大家學(xué)習(xí)學(xué)習(xí)。
this.changeIframeDivStyle(’none’);
解決方式
在iframe上添加透明遮罩層樣式
<div ref='box'> <div ref='left'> </div> <div ref='resize'> ⋮ </div> <div ref='mid'> <!--在此處添加遮罩層--> <div class='iframeDiv'></div> <iframe name='iFrame1' frameborder='0' scrolling='auto' :src='http://www.aoyou183.cn/bcjs/iframeUrl'> </iframe> </div> </div>
添加CSS樣式
.iframeDiv { width: 100%; height: 100%; position: absolute; z-index: 1111; filter: alpha(opacity=0); opacity: 0; background: transparent; margin-top: 30px; /*display: none;*/ }
添加鼠標(biāo)的監(jiān)聽(tīng)事件
在拖拽區(qū)添加鼠標(biāo)的按下事件和松開(kāi)事件
<div ref='resize' @mousedown='changeIframeDivStyle(’’)' @onmouseup='changeIframeDivStyle(’none’)' >⋮ </div>
添加方法
changeIframeDivStyle(display) { var iframeDiv = document.getElementsByClassName(’iframeDiv’); iframeDiv[0].style.display = display; },
設(shè)置頁(yè)面初始化加載
this.changeIframeDivStyle(’none’);
到此這篇關(guān)于vue中解決拖拽改變存在iframe的div大小時(shí)卡頓問(wèn)題的文章就介紹到這了,更多相關(guān)vue拖拽div卡頓內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. ASP基礎(chǔ)知識(shí)VBScript基本元素講解2. ajax請(qǐng)求添加自定義header參數(shù)代碼3. Gitlab CI-CD自動(dòng)化部署SpringBoot項(xiàng)目的方法步驟4. Kotlin + Flow 實(shí)現(xiàn)Android 應(yīng)用初始化任務(wù)啟動(dòng)庫(kù)5. Python requests庫(kù)參數(shù)提交的注意事項(xiàng)總結(jié)6. 基于javascript處理二進(jìn)制圖片流過(guò)程詳解7. 解決android studio引用遠(yuǎn)程倉(cāng)庫(kù)下載慢(JCenter下載慢)8. asp知識(shí)整理筆記4(問(wèn)答模式)9. axios和ajax的區(qū)別點(diǎn)總結(jié)10. 詳談ajax返回?cái)?shù)據(jù)成功 卻進(jìn)入error的方法
