如何在Vue中实现拖拽功能?

Vue.js是一款流行的JavaScript框架,用于构建用户界面。其中一个常见的需求是在Vue中实现拖拽功能,让用户可以通过拖拽元素来进行交互。今天,我们就来学习如何在Vue中实现这一功能。

首先,我们需要明白拖拽功能的基本原理:监听鼠标事件、实时更新拖拽元素的位置,最后在合适的时机停止拖拽并更新元素位置。在Vue中,我们可以通过绑定相关事件来实现这一功能。

效果展示

 代码展示

<!DOCTYPE HTML>
<html>
 
<head>
    <title>拖放示例-文本</title>
</head>
<style>
.src {
    display: flex;
}
 
.dropabled {
    flex: 1;
}
 
.txt {
    color: green;
}
 
.img {
    width: 100px;
    height: 100px;
    border: 1px solid gray;
}
 
.target {
    width: 200px;
    height: 200px;
    line-height: 200px;
    text-align: center;
    border: 1px solid gray;
    color: red;
}
</style>
 
<body>
    <div class="src">
        <div class="dragabled">
            <div class="txt" id="txt">
                所有的图片都可拖拽。
                <p draggable="true">
                    <img class="img" id="tupian1" src="1670483208231593.jpg" alt="图片1" />
                    <img class="img" id="tupian2" src="R-C.jfif" alt="图片2" />
                    </p>  
            </div>
          
          
        </div>
        <div id='target' class="dropabled target">拖到这</div>
    </div>
    <script>
        var dragSrc = document.getElementById('txt')
        var target = document.getElementById('target')
 
        dragSrc.ondragstart = handle_start
        dragSrc.ondrag = handle_drag
        dragSrc.ondragend = handle_end
 
        function handle_start(e) {
          console.log('拖拽1')
        }
 
      function handle_drag() {
            console.log('拖拽2')
        }
 
      function handle_end() {
        console.log('拖拽2')
        console.log('拖拽2')
    }
 
        target.ondragenter = handle_enter
        target.ondragover = handle_over
        target.ondragleave = handle_leave
 
        target.ondrop = handle_drop
 
        function handle_enter(e) {
            console.log('拖拽2')
            // 阻止浏览器默认行为
            e.preventDefault()
        }
 
        function handle_over(e) {
            console.log('拖拽2')
            // 阻止浏览器默认行为
            e.preventDefault()
        }
 
        function handle_leave(e) {
            console.log('拖拽2')
            // 阻止浏览器默认行为
            // e.preventDefault()
        }
 
        function handle_drop(e) {
            console.log('拖拽')
            var t = Date.now()
            target.innerHTML = ''
            target.append(t + '-拖拽')
            e.preventDefault()
        }
    </script>
</body>
 
</html>

相关推荐

  1. Vue3如何将一个div进行

    2024-07-10 23:52:04       23 阅读
  2. 实现功能实战示例

    2024-07-10 23:52:04       16 阅读
  3. ElementUI+sortablejs实现列表功能

    2024-07-10 23:52:04       28 阅读

最近更新

  1. 认识 Glob Pattern

    2024-07-10 23:52:04       0 阅读
  2. 重载和重写的区别

    2024-07-10 23:52:04       0 阅读
  3. 白骑士的PyCharm教学基础篇 1.3 调试与运行

    2024-07-10 23:52:04       0 阅读
  4. RK RGA _MMU unsupported memory larger then 4G!问题解决

    2024-07-10 23:52:04       0 阅读
  5. C语言中的指针函数和函数指针

    2024-07-10 23:52:04       0 阅读
  6. 人工智能:改变我们日常生活的无形力量

    2024-07-10 23:52:04       0 阅读
  7. F - Palindromic Expression (abc363)

    2024-07-10 23:52:04       0 阅读
  8. iOS应用冷启动优化,可以做哪些事情

    2024-07-10 23:52:04       0 阅读
  9. MySQL学习之事务,锁机制

    2024-07-10 23:52:04       0 阅读
  10. 神经架构搜索:目标检测的未来

    2024-07-10 23:52:04       0 阅读

热门阅读

  1. yolov5中训练长条型目标召回率低问题

    2024-07-10 23:52:04       8 阅读
  2. openssl error:0A000126:SSL routines:ssl3_read_n:unexpected eof

    2024-07-10 23:52:04       9 阅读
  3. 各种软件启动方式

    2024-07-10 23:52:04       6 阅读
  4. 【创作纪念日】我的三周年创作纪念日

    2024-07-10 23:52:04       7 阅读
  5. Github 2024-07-07 开源项目日报 Top10

    2024-07-10 23:52:04       8 阅读
  6. 部署LVS-DR群集

    2024-07-10 23:52:04       5 阅读
  7. python的列表推导式

    2024-07-10 23:52:04       8 阅读