日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

vue中解決拖拽改變存在iframe的div大小時卡頓問題

瀏覽:222日期:2022-12-31 10:02:59

寫在最前

針對于在vue中實現(xiàn)拖拽改變兩左右個div大小的方式,請查看上一篇文章《vue中實現(xiàn)拖動調(diào)整左右兩側(cè)div的寬度》。此文章主要針對于實際應用中需要拖拽改變大小的組件中使用iframe框架時存在明顯卡頓的問題,比如這樣,右側(cè)div中使用了一個iframe組件,導致實際操作中出現(xiàn)兩個問題,一個是拖不動,另外一個是無法根據(jù)鼠標移動,快速響應,甚至在監(jiān)聽鼠標的按下和松開事件上都有明顯的卡頓問題。如果去除右側(cè)iframe框架,則沒有問題。

有iframe情況

vue中解決拖拽改變存在iframe的div大小時卡頓問題

無iframe情況

vue中解決拖拽改變存在iframe的div大小時卡頓問題

vue中解決拖拽改變存在iframe的div大小時卡頓問題

問題原因&解決思路

問題原因我不知道,不過這個博客給了我解決思路《解決jqueryUI的拖拽,如果元素中含有iframe,拖動卡的問題》,還有以下說法,他們的解決思路一樣的。因此我猜想是鼠標的監(jiān)聽造成的影響,在我們拖拽的時候,因為拖拽過快,很容易出現(xiàn)鼠標移動超過拖拽范圍的情況,此時的鼠標可能已經(jīng)在iframe上方,從而會同時加載iframe中的內(nèi)容,導致出現(xiàn)卡頓。

總之,解決的思路就是在拖動的時候,在iframe上方添加一個透明的遮罩層,然后在停止拖拽的時候讓其消失。這樣問題就可以完美解決了。

vue中解決拖拽改變存在iframe的div大小時卡頓問題

解決方式共有兩節(jié),一節(jié)包含我解決過程中遇到的問題,一節(jié)是直接的解決方式,如果想直接查看解決方式的,請直接跳轉(zhuǎn)至解決方式那一節(jié)

解決方式(含解決過程中遇到的問題)

HTML組件部分源代碼

這是實現(xiàn)拖拽的組件代碼,如果不了解我原本使用的實現(xiàn)方式,請參考《vue中實現(xiàn)拖動調(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.b3g6.com/bcjs/iframeUrl'> </iframe> </div> </div>

添加遮罩層

在以上標注的地方,添加如下代碼

<div class='iframeDiv'></div>

再添加遮罩層的css樣式即可,此時最好測試點擊一下,是不是原來的ifame部分已經(jīng)不能點擊,而且拖拽起來已經(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;*/ }

實現(xiàn)遮罩層在拖拽時出現(xiàn)

我的解決辦法是直接在拖拽區(qū)域添加監(jiān)聽鼠標的按下和松開事件,按下后遮罩層出現(xiàn),松開后消失,因此修改resize部分,添加onmouseup&mousedown,分別傳入?yún)?shù),用于修改iframeDiv的css樣式中的display屬性值

<div ref='resize' @mousedown='changeIframeDivStyle(’’)' @onmouseup='changeIframeDivStyle(’none’)' >⋮ </div>

然后添加changeIframeDivStyle方法,因為getElementByClassName返回的是個數(shù)組集合,但是我又確認自己頁面只有一個iframeDiv,所以選擇了iframe[0],如果想使用getElementById也可以

changeIframeDivStyle(display) { var iframeDiv = document.getElementsByClassName(’iframeDiv’); iframeDiv[0].style.display = display; },

到此基本就算完成大半了,mousedown為鼠標按下事件,按下后設(shè)置display為空,即遮罩層出現(xiàn),onmouseup為鼠標松開事件,松開后遮罩層消失,達到不影響用戶操作查看iframe中內(nèi)容的目的

頁面初始化時遮罩層設(shè)置問題

按照實際來講,初始化進入頁面時,我們就不應該留有遮罩層,所以按照我的想法來講,就是直接在css中修改樣式,但是如上所見,我把它注釋掉了,至于為什么,先賣個關(guān)子,大家修改后嘗試一下,看看拖拽時卡頓不卡頓

display: none;

在我本以為這樣就可以解決問題時,我發(fā)現(xiàn),首次進入頁面,直接進行拖拽,依舊會存在卡頓,但是拖拽過一次之后,就不會再有問題了。這個問題,,我又不知道為什么了,于是,既然它需要拖拽一次之后才不會卡頓,那我就直接注釋掉了css中這個display樣式,反而在 mounted中添加方法,這樣反而成功了,雖然搞不明白兩者的差距,但是問題總算是解決了,如果有知道原因的朋友,可以在評論中分享出來,供大家學習學習。

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.b3g6.com/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;*/ }

添加鼠標的監(jiān)聽事件

在拖拽區(qū)添加鼠標的按下事件和松開事件

<div ref='resize' @mousedown='changeIframeDivStyle(’’)' @onmouseup='changeIframeDivStyle(’none’)' >⋮ </div>

添加方法

changeIframeDivStyle(display) { var iframeDiv = document.getElementsByClassName(’iframeDiv’); iframeDiv[0].style.display = display; },

設(shè)置頁面初始化加載

this.changeIframeDivStyle(’none’);

到此這篇關(guān)于vue中解決拖拽改變存在iframe的div大小時卡頓問題的文章就介紹到這了,更多相關(guān)vue拖拽div卡頓內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標簽: Vue
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
红桃视频欧美| 91久久久精品国产| 日韩欧美中文字幕电影| 日韩影院精彩在线| 日韩高清在线不卡| 综合色就爱涩涩涩综合婷婷| 亚洲精品一二| 久久不见久久见中文字幕免费| 久久精品一区二区三区中文字幕| 精品久久网站| 欧美~级网站不卡| 噜噜噜躁狠狠躁狠狠精品视频 | 欧美一区=区| 亚洲精品亚洲人成在线观看| 日韩精品免费视频一区二区三区| 免费一级欧美在线观看视频| 久久青草久久| 久久午夜视频| 国产欧美另类| 性感美女一区二区在线观看| 伊人精品视频| 国产精品va视频| 亚洲夜间福利| 国产毛片精品| 久久免费大视频| 日韩av一二三| 91看片一区| 日韩高清一区在线| 久久久久国产精品一区二区| 日韩亚洲精品在线观看| 国产在线观看91一区二区三区| 成人羞羞视频播放网站| 亚洲精品动态| 麻豆精品久久久| 尹人成人综合网| 美女性感视频久久| 石原莉奈在线亚洲二区| 精品视频亚洲| 亚洲tv在线| 日韩精品一区二区三区免费观影| 亚洲精品系列| 1000部精品久久久久久久久| 国产精品一级| 蜜臀久久久久久久| 秋霞影视一区二区三区| 国产欧美午夜| 免费在线观看精品| 亚洲va中文在线播放免费| 亚洲视频国产| 国产亚洲一区二区手机在线观看 | 91精品1区| 美女视频网站久久| 在线视频亚洲欧美中文| 国产精品成人一区二区不卡| 日韩精品视频在线看| 亚洲国产专区| 亚洲黄色网址| 少妇高潮一区二区三区99| 欧美aa一级| 国产精品久久国产愉拍| 亚洲ab电影| 久久xxxx| 91成人网在线观看| 国产 日韩 欧美一区| 精品国产一区二区三区av片| 日本免费新一区视频| 亚洲一区久久| 极品裸体白嫩激情啪啪国产精品| 开心激情综合| 国产免费播放一区二区| 午夜天堂精品久久久久| 亚洲激情另类| 激情欧美一区二区三区| 国产资源在线观看入口av| 麻豆一区二区三| 国产精品亚洲综合久久| 欧美片第1页综合| 日韩二区三区在线观看| 日韩在线视频一区二区三区| 天堂成人国产精品一区| 尤物网精品视频| 欧美日韩少妇| 欧美日韩国产免费观看| 国产精品7m凸凹视频分类| 欧美日韩高清| 婷婷亚洲综合| 日韩视频在线一区二区三区 | 中文av在线全新| 高清一区二区| 国产精品xx| 日本美女一区| 亚洲午夜久久久久久尤物| 日韩精品免费一区二区在线观看| 国产v日韩v欧美v| 92国产精品| 久久精品一区二区国产| 久久影院一区二区三区| 精品视频网站| 久久青青视频| 欧美日韩国产在线观看网站| 欧美在线资源| 亚洲影视一区二区三区| 日本午夜精品| 精品久久网站| 久久国产主播| 亚洲欧美视频一区二区三区| 视频在线观看91| 日韩一区中文| 国产精品啊啊啊| 国产激情在线播放| 日韩免费视频| 欧美 日韩 国产一区二区在线视频| 欧美在线网站| 日韩av网站在线免费观看| 欧美黑人巨大videos精品| 精品国产午夜| 99精品在线观看| 亚洲欧美不卡| 国产精品蜜月aⅴ在线| 精品资源在线| 婷婷精品视频| 日韩精品一页| 成人一区而且| 中文国产一区| 日韩亚洲精品在线观看| 欧美欧美黄在线二区| 国产伊人久久| 亚洲一区二区网站| 国产精品美女久久久久久不卡| 成人啊v在线| 最新亚洲国产| 精品久久不卡| 男女精品网站| 麻豆免费精品视频| 女人天堂亚洲aⅴ在线观看| 日韩不卡一二三区| 日韩在线短视频| 亚洲欧美在线专区| 久久久91麻豆精品国产一区| 图片区亚洲欧美小说区| 中文字幕亚洲精品乱码| 精品亚洲免a| 香蕉久久久久久久av网站| 国产精品99精品一区二区三区∴| 欧美亚洲精品在线| 国产精品s色| 日韩精品一二区| 四季av一区二区凹凸精品| 亚洲精品少妇| 亚洲无线一线二线三线区别av| 国产日韩欧美三区| 亚洲女同中文字幕| 麻豆成人av在线| 免费久久精品视频| 成人日韩在线| 欧美三级第一页| 精品一区免费| 国内不卡的一区二区三区中文字幕| 亚洲综合国产| 日韩中文视频| 免费日韩成人| 亚洲精品影院在线观看| 色老板在线视频一区二区| 欧美久久香蕉| 亚洲一区二区av| 亚洲国产专区校园欧美| 美腿丝袜亚洲一区| 日韩在线网址| 久久最新视频| 亚洲午夜一级| 精品黄色一级片| 日本不卡不码高清免费观看 | 97人人精品| 国产精品久一| 18国产精品| 亚洲精品字幕| 中文日韩欧美| 激情欧美一区二区三区| 国产va在线视频| 国产精品日韩精品在线播放 | 激情综合网站| 亚洲播播91| 久久av导航| 欧美日本久久| 亚洲91在线| 久久午夜视频| 午夜欧美精品久久久久久久| 电影天堂国产精品| 国产精品毛片久久| 成人在线视频免费看| 久久精品国产精品亚洲毛片| 国产视频一区二| 欧美久久亚洲| 国产麻豆精品| 国产精品115| 久久只有精品| 欧美国产视频| 国产午夜久久av| 国产欧美一区二区三区米奇| 欧美一级久久|