Vue实现开关按钮拖拽效果


Posted in Javascript onSeptember 22, 2020

本文实例为大家分享了Vue实现开关按钮拖拽效果的具体代码,供大家参考,具体内容如下

css:

<style>
  .box {
    position: absolute;
    left: 100px;
    top: 100px;
    width: 100px;
    height: 100px;
    background: red;
  }
  .box2 {
    position: absolute;
    left: 400px;
    top: 100px;
    width: 100px;
    height: 100px;
    background: green;
  }
</style>

html:

<div id="app">

  <div class="box" v-drag="isDrag"></div>

  <div class="box2" v-drag:fn.limit.b="isDrag"></div>

  <button @click="isDrag = !isDrag">{{isDrag}}</button>

</div>

js:

<script src="vue.js"></script>
<script>

  // 组件
  Vue.directive('drag', {
    bind(el, {value, arg, modifiers}) {
      console.log(value, arg, modifiers)
      el._value = value;
      el._isDrag = false;
      el.addEventListener('mousedown', function(e) {

        if (!el._value) return;

        el._isDrag = true;
        el._x = e.clientX - el.offsetLeft;
        el._y = e.clientY - el.offsetTop;

        e.preventDefault();
      });
      document.addEventListener('mousemove', function(e) {
        if (el._isDrag) {
          let l = e.clientX - el._x;
          let t = e.clientY - el._y;

          if (modifiers.limit) {
            if (l < 0) {
              l = 0;
            }
            if (t < 0) {
              t = 0;
            }
          }

          el.style.left = l + 'px';
          el.style.top = t + 'px';
        }
      });
      document.addEventListener('mouseup', function(e) {
        el._isDrag = false;
      });
    },

    componentUpdated(el, {value}) {
      console.log('更新了', value);
      el._value = value;
    }
  });

  let app = new Vue({
    el: '#app',
    data: {
      isDrag: false
    }
  });


</script>

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

Javascript 相关文章推荐
两个DIV等高的JS的实现代码
Dec 23 Javascript
学习ExtJS(二) Button常用方法
Oct 07 Javascript
Extjs4中的分页应用结合前后台
Dec 13 Javascript
使用百度地图api实现根据地址查询经纬度
Dec 11 Javascript
JS中script标签defer和async属性的区别详解
Aug 12 Javascript
JavaScript 继承详解(五)
Oct 11 Javascript
AngularJS使用ng-app自动加载bootstrap框架问题分析
Jan 04 Javascript
Three.js基础部分学习
Jan 08 Javascript
推荐三款日期选择插件(My97DatePicker、jquery.datepicker、Mobiscroll)
Apr 21 jQuery
uploader秒传图片到服务器完整代码
Apr 22 Javascript
在Node.js中将SVG图像转换为PNG,JPEG,TIFF,WEBP和HEIF格式的方法
Aug 22 Javascript
微信小程序实现点击按钮后修改颜色
Dec 05 Javascript
JS如何生成动态列表
Sep 22 #Javascript
vue使用svg文件补充-svg放大缩小操作(使用d3.js)
Sep 22 #Javascript
解决Can't find variable: SockJS vue项目的问题
Sep 22 #Javascript
解决vue-router 嵌套路由没反应的问题
Sep 22 #Javascript
Js跳出两级循环方法代码实例
Sep 22 #Javascript
vue 二维码长按保存和复制内容操作
Sep 22 #Javascript
vue-router 按需加载 component: () =&gt; import() 报错的解决
Sep 22 #Javascript
You might like
php类
2006/11/27 PHP
基于PHP Web开发MVC框架的Smarty使用说明
2013/04/19 PHP
PHP面向对象详解(三)
2015/12/07 PHP
mysql alter table命令修改表结构实例详解
2016/09/24 PHP
PHP高并发和大流量解决方案整理
2019/12/24 PHP
iphone safari不支持position fixed的解决方法
2012/05/04 Javascript
Js可拖拽放大的层拖动特效实现方法
2015/02/25 Javascript
全面解析Bootstrap中tab(选项卡)的使用方法
2016/06/06 Javascript
jquery实现简单Tab切换菜单效果
2020/07/17 Javascript
浅谈js中字符和数组一些基本算法题
2016/08/15 Javascript
ES6 系列之 Generator 的自动执行的方法示例
2018/10/19 Javascript
React中this丢失的四种解决方法
2019/03/12 Javascript
Vue infinite update loop的问题解决
2019/04/23 Javascript
详解关于React-Router4.0跳转不置顶解决方案
2019/05/10 Javascript
jquery html添加元素/删除元素操作实例详解
2020/05/20 jQuery
Vue如何基于vue-i18n实现多国语言兼容
2020/07/17 Javascript
在Echarts图中给坐标轴加一个标识线markLine
2020/07/20 Javascript
详解node.js创建一个web服务器(Server)的详细步骤
2021/01/15 Javascript
[01:33:07]VGJ.T vs Newbee Supermajor 败者组 BO3 第一场 6.6
2018/06/07 DOTA
[42:23]完美世界DOTA2联赛PWL S3 Forest vs Rebirth 第二场 12.10
2020/12/13 DOTA
Python中实现远程调用(RPC、RMI)简单例子
2014/04/28 Python
python将ansible配置转为json格式实例代码
2017/05/15 Python
python+OpenCV实现车牌号码识别
2019/11/08 Python
可视化pytorch 模型中不同BN层的running mean曲线实例
2020/06/24 Python
matplotlib绘制正余弦曲线图的实现
2021/02/22 Python
HTML5 离线应用之打造零请求、无流量网站的解决方法
2013/04/25 HTML / CSS
浅谈HTML5 服务器推送事件(Server-sent Events)
2017/08/01 HTML / CSS
什么是serialVersionUID
2016/03/04 面试题
外贸公司实习自我鉴定
2013/09/24 职场文书
企划经理的岗位职责
2013/11/17 职场文书
护士自我鉴定怎么写
2014/02/07 职场文书
2014年公务员思想汇报范文:全心全意为人民服务
2014/03/06 职场文书
纠纷协议书
2014/04/16 职场文书
美术兴趣小组活动总结
2014/07/07 职场文书
60条职场经典语录,总有一条能触动你的心
2019/08/21 职场文书
php中pcntl_fork详解
2021/04/01 PHP