vue中的可拖拽宽度div的实现示例
更新时间:2022年04月08日 09:45:03 作者:李剑一
本文主要介绍了vue中的可拖拽宽度div的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
主要思路
- 在需要拖拽宽度的区域设置一个div,高度设为 100%,宽度尽量窄一些(也不要太窄,3~6px左右)
- 在此div上绑定当“鼠标按下”时,触发document绑定“鼠标移动”方法和"鼠标抬起"方法
- 通过鼠标移动方法不断获取当前鼠标位置,设置需要变化大小div的宽高。
- 鼠标抬起时取消鼠标移动方法和鼠标抬起方法的绑定。
<template> <div class="container" id="content_box"> <div class="tab">左侧Tab</div> <div class="menu" ref="menu"> 左侧菜单 <div class="menu-resize" ref="menuResize"></div> </div> <div class="content"> 中心区域 <div class="opera" ref="opera"> <div class="opera-resize" ref="operaResize"></div> 操作区域 </div> </div> </div> </template> <script> export default { name: "dropWidth", mounted() { this.$nextTick(() => { this.dropSize(); }) }, methods: { dropSize() { let that = this, menuWidth = 200, operaHeight = 200; this.$refs.menuResize.onmousedown = function () { document.onmousemove = function (e) { let clientX = e.clientX; // 最大宽度 if(clientX>=330){ clientX = 330; } // 最小宽度 if(clientX<=230){ clientX = 230; } // TODO 这里减的是最左侧tab的宽度 menuWidth = clientX - 30; that.$refs.menu.style.width = clientX - 30 +"px"; } document.onmouseup = function () { console.log('当前宽度', menuWidth); document.onmousemove = null; document.onmouseup = null; that.releaseCapture && that.releaseCapture() } } this.$refs.operaResize.onmousedown = function () { document.onmousemove = function (e) { let clientY = e.clientY; console.log(clientY) // 最大宽度 if(clientY<=100){ clientY = 100; } // 最小宽度 if(clientY>=300){ clientY = 300; } operaHeight = clientY; // TODO 这里需要取反向 that.$refs.opera.style.height = 400 - clientY +"px"; } document.onmouseup = function () { console.log('当前宽度', operaHeight); document.onmousemove = null; document.onmouseup = null; that.releaseCapture && that.releaseCapture() } } } } } </script> <style scoped> .container { width: 1000px; height: 400px; border: 2px solid #dddddd; display: flex; justify-content: center; } .tab { width: 30px; height: 100%; background-color: #EC8C32; flex-shrink: 0; flex-grow: 0; } .menu { width: 200px; background-color: #AAB6E0; flex-shrink: 0; flex-grow: 0; position: relative; } .content { width: 100%; position: relative; } .opera { width: 100%; height: 200px; position: absolute; bottom: 0; background-color: #F2BE25; } .menu-resize { width: 5px; height: 100%; position: absolute; top: 0; right: 0; cursor: col-resize; } .opera-resize { width: 100%; height: 5px; position: absolute; top: 0; left: 0; cursor: row-resize; } </style>
实现效果
到此这篇关于vue中的可拖拽宽度div的实现示例的文章就介绍到这了,更多相关vue 可拖拽宽度div内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
客户端(vue框架)与服务器(koa框架)通信及服务器跨域配置详解
本篇文章主要介绍了客户端(vue框架)与服务器(koa框架)通信及服务器跨域配置详解,具有一定的参考价值,有兴趣的可以了解一下2017-08-08Nuxt3项目中问题汇总之刷新页面useFetch无返回解决
Nuxt.js是一个基于 Vue.js 的服务端渲染应用框架,这篇文章主要给大家介绍了关于Nuxt3项目中问题汇总之刷新页面useFetch无返回解决办法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下2024-03-03基于Vue3+Three.js实现一个3D模型可视化编辑系统
这篇文章主要介绍了基于Vue3+Three.js实现一个3D模型可视化编辑系统,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-09-09
最新评论