vue/Element?UI實現(xiàn)Element?UI?el-dialog自由拖動功能實現(xiàn)
前言:
最近有個項目,客戶要求彈窗可拖動,但是由于elemen ui本身的彈窗并沒有拖動的屬性,無法滿足客戶的需求。
于是我百度找到了幾篇文章,終于可以實現(xiàn)客戶的需求!
請往下看↓↓
一、新建一個目錄:utils
二、創(chuàng)建drag .js文件
/** * 拖拽移動 * @param {elementObjct} bar 鼠標點擊控制拖拽的元素 * @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)拖動功能了!
如果有不同看法,歡迎留言交流,謝謝!!
下面是一個博主的文章,大家不懂也可以參考一下
參考鏈接:http://chabaoo.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-07Elementui按鈕設(shè)置默認選中狀態(tài)的實現(xiàn)過程
這篇文章主要給大家介紹了關(guān)于Elementui按鈕設(shè)置默認選中狀態(tài)的實現(xiàn)過程,文中通過圖文以及示例代碼介紹的非常詳細,對大家學習或者使用Elementui具有一定的參考學習價值,需要的朋友可以參考下2023-07-07vue前端自適應(yīng)布局實現(xiàn)教程(一步到位所有自適應(yīng))
?自適應(yīng)布局是一種根據(jù)不同的設(shè)備屏幕分辨率進行布局的方式,它為不同的屏幕分辨率定義了不同的布局,下面這篇文章主要給大家介紹了關(guān)于vue前端自適應(yīng)布局實現(xiàn)的相關(guān)資料,需要的朋友可以參考下2024-08-08vue cli3中eslint報錯no-undef和eslint規(guī)則配置方式
這篇文章主要介紹了vue cli3中eslint報錯no-undef和eslint規(guī)則配置方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08