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

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

vue中實(shí)現(xiàn)拖動(dòng)調(diào)整左右兩側(cè)div的寬度的示例代碼

瀏覽:170日期:2022-12-31 11:03:01

寫在最前

最近在使用vue的時(shí)候,遇到一個(gè)需求,實(shí)現(xiàn)左右div可通過中間部分拖拽調(diào)整寬度,類似于這樣

vue中實(shí)現(xiàn)拖動(dòng)調(diào)整左右兩側(cè)div的寬度的示例代碼

這是我最終的實(shí)現(xiàn)效果

vue中實(shí)現(xiàn)拖動(dòng)調(diào)整左右兩側(cè)div的寬度的示例代碼

還是老話,因?yàn)槲也皇菍I(yè)的前端工程師,只是兼職寫一些簡單的前端,所以這個(gè)功能的實(shí)現(xiàn)得益于以下博客,《vue 拖動(dòng)調(diào)整左右兩側(cè)div的寬度》、《vuejs中拖動(dòng)改變元素寬度實(shí)現(xiàn)寬度自適應(yīng)大小》,而我只是針對于他們提供的代碼,加了億點(diǎn)點(diǎn)自己所需要的細(xì)節(jié)。

實(shí)現(xiàn)原理

vue中實(shí)現(xiàn)拖動(dòng)調(diào)整左右兩側(cè)div的寬度的示例代碼

如上圖所示,我們需要將要實(shí)現(xiàn)此功能的頁面劃分為三個(gè)部分,左部、調(diào)整區(qū)、右部,分別對應(yīng)css樣式為left、resize、mid,然后將這三個(gè)div放在css樣式為box的div中即可

實(shí)現(xiàn)代碼-HTML部分

將以下代碼放置在vue頁面文件中<templete></templete>標(biāo)簽內(nèi)即可

<div ref='box'> <div class='left'> <!--左側(cè)div內(nèi)容--> </div> <div > ⋮ </div> <div class='mid'> <!--右側(cè)div內(nèi)容--> </div> </div>

實(shí)現(xiàn)代碼-CSS部分

將以下代碼放置在<style> </style>標(biāo)簽內(nèi)中即可

/* 拖拽相關(guān)樣式 */ /*包圍div樣式*/ .box { width: 100%; height: 100%; margin: 1% 0px; overflow: hidden; box-shadow: -1px 9px 10px 3px rgba(0, 0, 0, 0.11); } /*左側(cè)div樣式*/ .left { width: calc(32% - 10px); /*左側(cè)初始化寬度*/ height: 100%; background: #FFFFFF; float: left; } /*拖拽區(qū)div樣式*/ .resize { cursor: col-resize; float: left; position: relative; top: 45%; background-color: #d6d6d6; border-radius: 5px; margin-top: -10px; width: 10px; height: 50px; background-size: cover; background-position: center; /*z-index: 99999;*/ font-size: 32px; color: white; } /*拖拽區(qū)鼠標(biāo)懸停樣式*/ .resize:hover { color: #444444; } /*右側(cè)div’樣式*/ .mid { float: left; width: 68%; /*右側(cè)初始化寬度*/ height: 100%; background: #fff; box-shadow: -1px 4px 5px 3px rgba(0, 0, 0, 0.11); }

實(shí)現(xiàn)代碼-拖拽事件部分

將以下代碼放置在methods方法區(qū)即可

dragControllerDiv: function () { var resize = document.getElementsByClassName(’resize’); var left = document.getElementsByClassName(’left’); var mid = document.getElementsByClassName(’mid’); var box = document.getElementsByClassName(’box’); for (let i = 0; i < resize.length; i++) { // 鼠標(biāo)按下事件 resize[i].onmousedown = function (e) { //顏色改變提醒 resize[i].style.background = ’#818181’; var startX = e.clientX; resize[i].left = resize[i].offsetLeft; // 鼠標(biāo)拖動(dòng)事件 document.onmousemove = function (e) { var endX = e.clientX; var moveLen = resize[i].left + (endX - startX); // (endx-startx)=移動(dòng)的距離。resize[i].left+移動(dòng)的距離=左邊區(qū)域最后的寬度 var maxT = box[i].clientWidth - resize[i].offsetWidth; // 容器寬度 - 左邊區(qū)域的寬度 = 右邊區(qū)域的寬度 if (moveLen < 32) moveLen = 32; // 左邊區(qū)域的最小寬度為32px if (moveLen > maxT - 150) moveLen = maxT - 150; //右邊區(qū)域最小寬度為150px resize[i].style.left = moveLen; // 設(shè)置左側(cè)區(qū)域的寬度 for (let j = 0; j < left.length; j++) {left[j].style.width = moveLen + ’px’;mid[j].style.width = (box[i].clientWidth - moveLen - 10) + ’px’; } }; // 鼠標(biāo)松開事件 document.onmouseup = function (evt) { //顏色恢復(fù) resize[i].style.background = ’#d6d6d6’; document.onmousemove = null; document.onmouseup = null; resize[i].releaseCapture && resize[i].releaseCapture(); //當(dāng)你不在需要繼續(xù)獲得鼠標(biāo)消息就要應(yīng)該調(diào)用ReleaseCapture()釋放掉 }; resize[i].setCapture && resize[i].setCapture(); //該函數(shù)在屬于當(dāng)前線程的指定窗口里設(shè)置鼠標(biāo)捕獲 return false; }; } },

然后在mouted初始化加載部分添加即可

this.dragControllerDiv();

結(jié)語

雖然以上代碼就可以實(shí)現(xiàn)左右div拖拽放大縮小了,但是實(shí)際應(yīng)用中我遇到了一個(gè)更棘手的問題,那就是如果在某一個(gè)div中使用iframe框架的話,拖拽時(shí)會(huì)存在明顯的卡頓,如果你在使用過程中遇到這個(gè)問題,可以查看我的下一篇文章vue中解決拖拽改變存在iframe的div大小時(shí)卡頓問題

到此這篇關(guān)于vue中實(shí)現(xiàn)拖動(dòng)調(diào)整左右兩側(cè)div的寬度的示例代碼的文章就介紹到這了,更多相關(guān)vue 拖動(dòng)調(diào)整左右兩側(cè)div寬度內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Vue
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
精品一区免费| 国产亚洲精品美女久久| 亚洲国产影院| 日本中文字幕一区二区视频| 国产精品99久久免费| 亚洲激情精品| 国内揄拍国内精品久久| 99在线|亚洲一区二区| 久久亚洲黄色| 日韩高清在线一区| 国产传媒在线观看| 欧美日韩亚洲一区三区| 在线综合视频| 国产综合色区在线观看| 国产精品美女久久久久久不卡| 亚洲激情中文| 日韩在线欧美| 国产精久久一区二区| 欧美精品中文字幕亚洲专区| 欧美日韩国产高清电影| 国产aⅴ精品一区二区四区| 日精品一区二区三区| 丝袜美腿亚洲一区二区图片| 亚洲精品99| 九九综合九九| 国产成人久久精品麻豆二区| 亚洲日产国产精品| 婷婷久久一区| 欧美天堂亚洲电影院在线观看| 最近高清中文在线字幕在线观看1| 69堂免费精品视频在线播放| 亚洲专区视频| 亚洲欧洲日韩| 欧美日韩一区二区三区四区在线观看| 亚洲欧美专区| 欧美日韩亚洲一区在线观看| 国产毛片久久久| 日韩综合一区二区| 国产免费av国片精品草莓男男| 欧美日本久久| 国产亚洲人成a在线v网站| 国产精品亚洲二区| 狠狠久久伊人中文字幕| 国产精品麻豆久久| 亚洲高清av| 国产模特精品视频久久久久| 日本不卡视频一二三区| 国产精品videossex| 欧美国产一级| 婷婷综合社区| 美国三级日本三级久久99| 日韩av成人高清| 四虎成人av| 天使萌一区二区三区免费观看| 日韩黄色免费网站| 麻豆一区在线| 模特精品在线| 久久久久亚洲精品中文字幕| 激情婷婷亚洲| 日本不卡视频在线| 中文字幕在线视频久| 视频一区视频二区在线观看| 久久久精品区| 亚洲免费一区二区| 另类综合日韩欧美亚洲| 精品在线播放| 精品精品久久| 婷婷成人av| 欧美搞黄网站| 久久99青青| 中文久久精品| 四季av一区二区凹凸精品| 亚洲一二av| 亚洲区第一页| 日韩午夜视频在线| 中文字幕亚洲精品乱码| 性一交一乱一区二区洋洋av| 国内亚洲精品| 一本大道色婷婷在线| 国内一区二区三区| 精品国产乱码久久久久久1区2匹| 欧美精品三级在线| 国产精品v日韩精品v欧美精品网站 | 欧美三级精品| 亚洲天堂一区二区| 久久亚洲成人| 亚洲欧美网站| 国产免费久久| 国产中文在线播放| 亚洲永久字幕| 国产精品视频3p| 成人免费一区| 狠狠爱成人网| 国产精品18| 91精品国产乱码久久久久久久| 日韩中文欧美在线| 精品一区91| 水野朝阳av一区二区三区| 日韩亚洲精品在线观看| 精品久久久亚洲| 亚洲成人精选| 日韩手机在线| 蜜臀国产一区| 美女黄网久久| 国产一区日韩| 午夜日韩av| jizzjizz中国精品麻豆| 极品裸体白嫩激情啪啪国产精品| 亚洲网站视频| 亚洲2区在线| 国产模特精品视频久久久久| 日本在线成人| 中文字幕高清在线播放| 欧美精品资源| 国产精品一区二区中文字幕| 国产中文在线播放| 视频在线观看国产精品| 国产精品激情电影| 久久精品影视| 911亚洲精品| 久久国产中文字幕| 日本免费新一区视频| 激情视频网站在线播放色| 欧美精品激情| 色综合狠狠操| www.51av欧美视频| 亚洲经典在线| 精品久久免费| 999国产精品999久久久久久| 一区在线免费| 韩日一区二区| 97精品国产一区二区三区| 日韩成人三级| 久久国产尿小便嘘嘘| 欧美~级网站不卡| 国产精品欧美在线观看| 亚洲一区日韩在线| 另类中文字幕国产精品| 国产精品多人| 久久99久久久精品欧美| 亚洲毛片网站| 蜜臀久久精品| 成人在线超碰| 日韩高清一区| 麻豆亚洲精品| 色爱av综合网| 精品三区视频| 国产精品久久久久久久久久齐齐| 一本色道精品久久一区二区三区| 欧美日韩国产v| 国产不卡精品| 国产精品国产三级国产在线观看| 国产探花一区| 奇米亚洲欧美| 国产欧美三级| 欧美一级全黄| 国产亚洲人成a在线v网站| 亚洲综合婷婷| 夜夜嗨av一区二区三区网站四季av| 蜜桃精品在线| 久久国产电影| 亚洲欧美视频一区二区三区| 亚洲激情久久| 欧美资源在线| 先锋影音国产一区| 最新国产精品| 欧美一级二级三级视频| 日韩成人av影视| 国产美女亚洲精品7777| 欧美在线日韩| 电影91久久久| 国产主播一区| 亚洲三级在线| 青青青国产精品| 麻豆精品99| 嫩草伊人久久精品少妇av杨幂| 久久精品国产网站| 亚洲福利国产| 日韩一区二区三区精品视频第3页| 97久久亚洲| 中文字幕人成乱码在线观看| 久久亚洲精品中文字幕蜜潮电影| 久久国产福利| 国产精品久久久久9999高清| 国产粉嫩在线观看| 女同性一区二区三区人了人一| 免费成人av在线播放| 国产精品2023| 亚洲二区免费| 国产精品亚洲成在人线| 欧美一区二区三区激情视频| 久久字幕精品一区| 国产亚洲毛片在线| 高清日韩中文字幕| 亚洲小说春色综合另类电影| 老司机免费视频一区二区| 久久精品官网| 久久精品免费看| 中文字幕一区二区三区四区久久| 国产精品欧美大片|