虚位以待(AD)
虚位以待(AD)
首页 > 网页特效 > JavaScript > 基于Vue实现拖拽功能

基于Vue实现拖拽功能
类别:JavaScript   作者:码皇   来源:互联网   点击:

这篇文章主要为大家详细介绍了Vue实现拖拽功能,拖动方块进行移动,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

效果图:

HTML代码:

    <div id="box"> 位置 <br>x:{
    {
    val.x}
    }
    <br>y:{
    {
    val.y}
    }
    <div v-drag="greet" id="drag" :style="style"> //注意这里要通过指令绑定函数将当前元素的位置数据传出来 </div></div>

JS代码:

    Vue.directive('drag',//自定义指令 {
    bind:function (el, binding) {
    let oDiv = el;
    //当前元素 let self = this;
    //上下文 oDiv.onmousedown = function (e) {
    //鼠标按下,计算当前元素距离可视区的距离 let disX = e.clientX - oDiv.offsetLeft;
    let disY = e.clientY - oDiv.offsetTop;
    document.onmousemove = function (e) {
    //通过事件委托,计算移动的距离 let l = e.clientX - disX;
    let t = e.clientY - disY;
    //移动当前元素 oDiv.style.left = l + 'px';
    oDiv.style.top = t + 'px';
    //将此时的位置传出去 binding.value({
    x:e.pageX,y:e.pageY}
    ) }
    ;
    document.onmouseup = function (e) {
    document.onmousemove = null;
    document.onmouseup = null;
    }
    ;
    }
    ;
    }
    }
    );
    window.onload = function () {
    let vm = new Vue({
    el: '#box', data: {
    val: '123', style: {
    width: '100px', height: '100px', background: 'aqua', position: 'absolute', right: '30px', top: 0 }
    }
    , methods:{
    //接受传来的位置数据,并将数据绑定给data下的val greet(val){
    vm.val = val;
    }
    }
    , }
    );
    }

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

您可能感兴趣的文章:

  • 基于vue-simplemde实现图片拖拽、粘贴功能
  • vue使用drag与drop实现拖拽的示例代码
  • Vue.Draggable实现拖拽效果
  • vuejs2.0运用原生js实现简单的拖拽元素功能示例
  • vue2.0使用Sortable.js实现的拖拽功能示例
  • Vue自定义指令拖拽功能示例
  • Vue.js实现图片的随意拖动方法
  • Vue实现带进度条的文件拖动上传功能
  • jQuery与vue实现拖动验证码功能
  • Vue.js实现拖放效果的实例
相关热词搜索: Vue 拖拽