欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Vue自定义指令拖拽功能示例

程序员文章站 2022-06-07 23:27:44
下面给大家分享vue自定义指令拖拽功能代码,具体代码如下所示: &...

下面给大家分享vue自定义指令拖拽功能代码,具体代码如下所示:

 <!doctype html>
<html lang="en">
<head>
 <meta charset="utf-8">
 <title>实例方法</title>
 <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0">
 <meta name="apple-mobile-web-app-capable" content="yes">
 <meta name="apple-mobile-web-app-status-bar-style" content="black">
 <script src="../js/vue1.0.js"></script>
 <script src="../js/vue-resource.js"></script>
 <script>
  //自定义指令
  vue.directive('drag',function(){
   var odiv = this.el;
   odiv.onmousedown = function(ev){
    var disx = ev.clientx -odiv.offsetleft;
    var disy = ev.clienty - odiv.offsettop;
    document.onmousemove = function(ev){
     var l = ev.clientx-disx;
     var t = ev.clienty-disy;
     odiv.style.left = l+'px';
     odiv.style.top = t+'px';
    };
    document.onmouseup = function(){
     document.onmousemove=null;
     document.onmouseup=null;
    };
   };
  });
  window.onload = function(){
   var vm = new vue({
    el:'#box',
    data:{}
   });
  }
 </script>
</head>
<body>
<div id="box">
 <div v-drag :style="{width:'100px', height:'100px', background:'aqua', position:'absolute', right:0, top:0}">
 </div>
</div>
</body>
</html>

下面看下vue自定义键盘信息

<!doctype html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>自定义键盘信息</title>
  <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0">
  <meta name="apple-mobile-web-app-capable" content="yes">
  <meta name="apple-mobile-web-app-status-bar-style" content="black">
  <script src="../js/vue1.0.js"></script>
  <script src="../js/vue-resource.js"></script>
  <script>
    vue.directive('on').keycodes.ctrl=17;
    vue.directive('on').keycodes.myenter=13;
    window.onload = function(){
      var vm = new vue({
        el:'#box',
        data:{},
        methods:{
          show:function(){
            alert(111);
          }
        }
      });
    }
  </script>
</head>
<body>
<div id="box">
  <input type="text" @keydown.ctrl="show">
  <hr>
  <input type="text" @keydown.myenter="show | debounce 2000">
</div>
</body>
</html>

以上所述是小编给大家介绍的vue自定义指令拖拽功能及键盘信息,希望对大家有所帮助