• 如何在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>
  • 相关阅读:
    作业20170928--2 单元测试
    作业20170928—1代码规范,结对要求
    第三周PSP
    20170922-3 功能测试作业
    第二周PSP
    采用c#实现功能1
    linux下搭建生成HLS所需的.ts和.m3u8文件
    android编译ffmpeg+x264
    ubuntu.sh: 113: ubuntu.sh: Syntax error: "(" unexpected
    解决:[WARNING] fpm_children_bury(), line 215: child 2736 (pool default) exited on signal 15 SIGTERM after 59.588363 seconds from start
  • 原文地址:https://www.cnblogs.com/BluceLee/p/9317701.html
Copyright © 2020-2023  润新知