iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >Vue实现拖拽式分割布局
  • 465
分享到

Vue实现拖拽式分割布局

2024-04-02 19:04:59 465人浏览 泡泡鱼
摘要

本文实例为大家分享了Vue实现拖拽式分割布局的具体代码,供大家参考,具体内容如下 示例展示 代码 特地写了一个demo代码,可以直接复制下来运行 <!DOCTYPE html

本文实例为大家分享了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{
    
    
    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>

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

--结束END--

本文标题: Vue实现拖拽式分割布局

本文链接: https://www.lsjlt.com/news/143314.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作