Vue实现拖拽式分割布局

 更新时间:2022年03月21日 15:48:26   作者:默默的小跟班  
这篇文章主要为大家详细介绍了Vue实现拖拽式分割布局,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了Vue实现拖拽式分割布局的具体代码,供大家参考,具体内容如下

示例展示

代码

特地写了一个demo代码,可以直接复制下来运行

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
    <title>Document</title>
</head>
<body>
<div id="app">
  <div class='container' id='container'>
    <div id='top' class='top'>top</div>
    <div id='bar' class='bar'></div>
    <div id='bottom' class='bottom'>bottom</div>
  </div>
</div>
<script>
var app = new Vue({
    el: '#app',
    data: {
    },
    mounted(){
      this.dragChangeHeight('bar','top')
    },
    methods:{
      dragChangeHeight(drag, panel) {
        var dragEl = document.getElementById(drag)
        var panelEl = document.getElementById(panel)
        dragEl.onmousedown = function(ev) {
          var disH = panelEl.offsetHeight
          var disY = ev.clientY
          var disT = panelEl.offsetTop
          var b = ''
          
          document.onmousemove = function(ev) {
            panelEl.style.height = disH + (ev.clientY - disY) + 'px'
            // panelEl.style.top = disL - (ev.clientY - disY) + 'px'
          }

          document.onmouseup = function() {
            document.onmousemove = document.onmouseup = null
          }
          return false
        }
      },
      dragChangeWidth(drag, panel) {
        var dragEl = document.getElementById(drag)
        var panelEl = document.getElementById(panel)
        dragEl.onmousedown = function(ev) {
          var disW = panelEl.offsetWidth
          var disX = ev.clientX
          var disL = panelEl.offsetLeft
          var b = ''

          document.onmousemove = function(ev) {
              panelEl.style.width = disW + (ev.clientX - disX) + 'px'
              // panelEl.style.left = disL - (ev.clientX - disX) + 'px'
          }

          document.onmouseup = function() {
            document.onmousemove = document.onmouseup = null
          }
          return false
        }
      },
    }
})
</script>

<style>
  body{
    margin: 0;
  }
  .container{
    /* padding: 20px; */
    
    height: 90vh;
    width: 90vw;
    display: flex;
    flex-direction: column;
  }
  .top{
    width: 100%;
    height: 300px;
    background-color: blue;
  }
  .bar{
    width: 100%;
    height: 10px;
    cursor: n-resize;
    background-color: black;
  }
  .bottom{
    width: 100%;
    flex: auto;
    background-color: red;
  }
</style>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • vue组合式API浅显入门示例详解

    vue组合式API浅显入门示例详解

    这篇文章主要为大家介绍了vue组合式API浅显入门示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • Vue computed计算属性总结记录

    Vue computed计算属性总结记录

    在vue中,有时候你需要对data中的数据进行处理,或者对抓取的数据进行处理之后再挂载呈现到标签中,这时候你就需要计算属性了,当然看到这里你可能还是不了解那下面我举几个实例并附代码解释
    2023-02-02
  • vue实现移动端项目多行文本溢出省略

    vue实现移动端项目多行文本溢出省略

    这篇文章主要介绍了vue实现移动端项目多行文本溢出省略功能,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07
  • vue slot 在子组件中显示父组件传递的模板

    vue slot 在子组件中显示父组件传递的模板

    这篇文章主要介绍了vue slot 在子组件中显示父组件传递的模板,需要的朋友可以参考下
    2018-03-03
  • 从源码角度来回答keep-alive组件的缓存原理

    从源码角度来回答keep-alive组件的缓存原理

    这篇文章主要介绍了从源码角度来回答keep-alive组件的缓存原理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01
  • vue中keep-alive、activated的探讨和使用详解

    vue中keep-alive、activated的探讨和使用详解

    这篇文章主要介绍了vue中keep-alive、activated的探讨和使用详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07
  • Vue3 实现验证码倒计时功能

    Vue3 实现验证码倒计时功能

    这篇文章主要介绍了Vue3 实现验证码倒计时功能,倒计时的运用场景是获取手机验证码倒计时、获取邮箱验证码倒计时等场景,本文结合示例代码给大家详细讲解,需要的朋友可以参考下
    2023-01-01
  • 基于vue-resource jsonp跨域问题的解决方法

    基于vue-resource jsonp跨域问题的解决方法

    下面小编就为大家分享一篇基于vue-resource jsonp跨域问题的解决方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-02-02
  • vue 组件间的通信之子组件向父组件传值的方式

    vue 组件间的通信之子组件向父组件传值的方式

    这篇文章主要介绍了vue 组件间的通信之子组件向父组件传值的方式总结,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-07-07
  • vue3中Fragment特性的一个bug需要注意事项

    vue3中Fragment特性的一个bug需要注意事项

    这篇文章主要介绍了vue3中Fragment特性的一个bug,需要留意的注意事项示例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2024-01-01

最新评论