zoukankan      html  css  js  c++  java
  • 如何在HTML 5中拖动光标图标?

    window.app = {
      dragging: false,
      config: {
        canDrag: false,
        cursorOffsetX: null,
        cursorOffsetY: null
      },
      reset: function () {
        this.config.cursorOffsetX = null;
        this.config.cursorOffsetY = null;
      },
      start: function () {
        document.getElementById('target').addEventListener('mousedown', function (event) {
          console.log('+++++++++++++ dragstart');
          this.dragging = true;
          this.config.cursorOffsetX = event.offsetX;
          this.config.cursorOffsetY = event.offsetY;
          this.adjustPostion(event);
        }.bind(this));
        document.getElementById('target').addEventListener('mousemove', function (event) {
          if (this.dragging) {
            console.log('+++++++++++++ drag');
            event.target.style.cursor = 'move'; 
            this.adjustPostion(event);
          }
        }.bind(this));
        document.getElementById('target').addEventListener('mouseup', function (event) {
          console.log('+++++++++++++ dragend');
          this.dragging = false;
          event.target.style.cursor = 'pointer'; 
          this.reset();
        }.bind(this));
      },
      adjustPostion: function (event) {
        if (event.clientX <= 0 || event.clientY <= 0) {
          console.log('skipped');
          return;
        }
        var elm = document.getElementById('target');
        elm.style.left = (event.clientX - this.config.cursorOffsetX) + 'px';
        elm.style.top = (event.clientY - this.config.cursorOffsetY) + 'px';
        console.log(event.pageX);
        console.log(event.pageY);
      }
    
    };
    #target {
                position: absolute;
                top: 100px;
                left: 100px;
                width: 400px;
                height: 400px;
                background-color: red;
                -moz-user-select: none;
                -ms-user-select: none;
                -webkit-user-select: none;
                user-select: none;
            }
    
            #ui1 {
                position: absolute;
                top: 50px;
                left: 50px;
                width: 100px;
                height: 400px;
                background-color: blue;
                z-index: 100;
            }
    
            #ui2 {
                position: absolute;
                top: 50px;
                left: 550px;
                width: 100px;
                height: 400px;
                background-color: green;
                z-index: 100;
            }
    <!-- simulate -->
    
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="utf-8">
        <title>title</title>
    </head>
    <body onload="window.app.start();">
        <div id="ui1"></div>
        <div id="ui2"></div>
        <div id="target"></div>
    </body>
    </html>
  • 相关阅读:
    (IOCP)-C#高性能Socket服务器的实现
    GraphQL和RESTful的区别
    HTTP Client Performance Improvements
    foobar2000 iOS使用,并连接PC的歌曲进行播放
    Spring中基于AOP的@AspectJ
    Spring中基于AOP的XML架构
    Spring框架的AOP
    Spring的AOP AspectJ切入点语法详解(转)
    Spring中实现自定义事件
    Spring的事件处理
  • 原文地址:https://www.cnblogs.com/BluceLee/p/9317701.html
Copyright © 2011-2022 走看看