vue/Element?UI實現(xiàn)Element?UI?el-dialog自由拖動功能實現(xiàn)
前言:
最近有個項目,客戶要求彈窗可拖動,但是由于elemen ui本身的彈窗并沒有拖動的屬性,無法滿足客戶的需求。
于是我百度找到了幾篇文章,終于可以實現(xiàn)客戶的需求!
請往下看↓↓
一、新建一個目錄:utils

二、創(chuàng)建drag .js文件
/**
* 拖拽移動
* @param {elementObjct} bar 鼠標(biāo)點擊控制拖拽的元素
* @param {elementObjct} target 移動的元素
* @param {function} callback 移動后的回調(diào)
*/
export function startDrag(bar, target, callback) {
var params = {
top: 0,
left: 0,
currentX: 0,
currentY: 0,
flag: false,
cWidth: 0,
cHeight: 0,
tWidth: 0,
tHeight: 0
};
// 給拖動塊添加樣式
bar.style.cursor = 'move';
// 獲取相關(guān)CSS屬性
// o是移動對象
// var getCss = function (o, key) {
// return o.currentStyle ? o.currentStyle[key] : document.defaultView.getComputedStyle(o, false)[key];
// };
bar.onmousedown = function (event) {
// 按下時初始化params
var e = event ? event : window.event;
params = {
top: target.offsetTop,
left: target.offsetLeft,
currentX: e.clientX,
currentY: e.clientY,
flag: true,
cWidth: document.body.clientWidth,
cHeight: document.body.clientHeight,
tWidth: target.offsetWidth,
tHeight: target.offsetHeight
};
// 給被拖動塊初始化樣式
target.style.margin = 0;
target.style.top = params.top + 'px';
target.style.left = params.left + 'px';
if (!event) {
// 防止IE文字選中
bar.onselectstart = function () {
return false;
}
}
document.onmousemove = function (event) {
// 防止文字選中
window.getSelection ? window.getSelection().removeAllRanges() : document.selection.empty();
var e = event ? event : window.event;
if (params.flag) {
var nowX = e.clientX;
var nowY = e.clientY;
// 差異距離
var disX = nowX - params.currentX;
var disY = nowY - params.currentY;
// 最終移動位置
var zLeft = 0;
var zTop = 0;
zLeft = parseInt(params.left) + disX;
// 限制X軸范圍
if (zLeft <= -parseInt(params.tWidth / 2)) {
zLeft = -parseInt(params.tWidth / 2);
}
if (zLeft >= params.cWidth - parseInt(params.tWidth * 0.5)) {
zLeft = params.cWidth - parseInt(params.tWidth * 0.5);
}
zTop = parseInt(params.top) + disY;
// 限制Y軸范圍
if (zTop <= 0) {
zTop = 0;
}
if (zTop >= params.cHeight - parseInt(params.tHeight * 0.5)) {
zTop = params.cHeight - parseInt(params.tHeight * 0.5);
}
// 執(zhí)行移動
target.style.left = zLeft + 'px';
target.style.top = zTop + 'px';
}
if (typeof callback == "function") {
callback(zLeft, zTop);
}
}
document.onmouseup = function () {
params.flag = false;
document.onmousemove = null;
document.onmouseup = null;
};
};
}三、創(chuàng)建directive.js 文件
// 引入拖拽js
import { startDrag } from './drag.js'
/**
* 為el-dialog彈框增加拖拽功能
* @param {*} el 指定dom
* @param {*} binding 綁定對象
* desc 只要用到了el-dialog的組件,都可以通過增加v-draggable屬性變?yōu)榭赏献У膹椏?
*/
const draggable = (el, binding) => {
// 綁定拖拽事件 [綁定拖拽觸發(fā)元素為彈框頭部、拖拽移動元素為整個彈框]
startDrag(el.querySelector('.el-dialog__header'), el.querySelector('.el-dialog'), binding.value);
};
const directives = {
draggable,
};
// 這種寫法可以批量注冊指令
export default {
install(Vue) {
Object.keys(directives).forEach((key) => {
Vue.directive(key, directives[key]);
});
},
};四、main.js文件中全局引入vue指令
全局注冊
import directive from './utils/directive' Vue.use(directive)
五、使用v-draagble
在頁面上使用v-draagble

好了,經(jīng)過以上的幾步,已經(jīng)可以實現(xiàn)拖動功能了!
如果有不同看法,歡迎留言交流,謝謝?。?/p>
下面是一個博主的文章,大家不懂也可以參考一下
參考鏈接:http://www.dbjr.com.cn/article/234469.htm
總結(jié)
到此這篇關(guān)于vue/Element UI實現(xiàn)Element UI el-dialog自由拖動功能實現(xiàn)的文章就介紹到這了,更多相關(guān)Element UI el-dialog自由拖動內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue常用的數(shù)字孿生可視化的自適應(yīng)方案
這篇文章主要為大家介紹了vue常用的數(shù)字孿生可視化的自適應(yīng)方案詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-07-07
Elementui按鈕設(shè)置默認(rèn)選中狀態(tài)的實現(xiàn)過程
這篇文章主要給大家介紹了關(guān)于Elementui按鈕設(shè)置默認(rèn)選中狀態(tài)的實現(xiàn)過程,文中通過圖文以及示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Elementui具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2023-07-07
vue前端自適應(yīng)布局實現(xiàn)教程(一步到位所有自適應(yīng))
?自適應(yīng)布局是一種根據(jù)不同的設(shè)備屏幕分辨率進行布局的方式,它為不同的屏幕分辨率定義了不同的布局,下面這篇文章主要給大家介紹了關(guān)于vue前端自適應(yīng)布局實現(xiàn)的相關(guān)資料,需要的朋友可以參考下2024-08-08
vue cli3中eslint報錯no-undef和eslint規(guī)則配置方式
這篇文章主要介紹了vue cli3中eslint報錯no-undef和eslint規(guī)則配置方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08

