>웹 프론트엔드 >JS 튜토리얼 >Javascript 드래그 앤 드롭의 일부 고급 응용 프로그램(코드를 한 줄씩 분석하여 드래그 앤 드롭의 원리를 쉽게 이해할 수 있음)_javascript 기술

Javascript 드래그 앤 드롭의 일부 고급 응용 프로그램(코드를 한 줄씩 분석하여 드래그 앤 드롭의 원리를 쉽게 이해할 수 있음)_javascript 기술

WBOY
WBOY원래의
2016-05-16 16:18:101315검색

이전 드래그 주변에 물건이 있으면 어떤 문제가 발생하는지 볼까요? 고급 브라우저에서는 문제가 없을 것입니다. IE7에서 테스트해 보면 문제가 나타날 것입니다. 사진과 같이

텍스트가 선택되었음을 확실히 알 수 있습니다. 그렇다면 이 사용자 경험은 매우 나쁘고 사용하기 불편합니다. 그런데 이전에 return false를 추가했는데, 이는 많은 문제를 해결하는 데 도움이 되었습니다. 이를 제거하면 크롬에서도 동일한 문제가 발생합니다. 이는 false 반환이 Chrome ff IE9와 같은 브라우저의 문제를 해결할 수 있음을 의미합니다.

실제로 우리 개발에서는 페이지에 많은 요소가 있을 것입니다. 하나의 div만 사용할 수는 없으며, Baidu 지도와 같은 다른 장소는 선택되지 않습니다.
그렇다면 우리는 어떻게 그러한 끌림을 달성할 수 있을까요? IE7의 문제를 해결할 수 있나요?

해결책:

이 문제를 해결하기 위해 약간의 트릭을 사용할 수 있습니다. 다른 브라우저에서는 return false를 사용하기 때문에 이 트릭은 IE6-8에서만 지원되며 실제로 문제를 해결할 수 있습니다. 어떤 기술이 있는지 살펴보겠습니다

이벤트 캡쳐입니다! ! 간단한 설명과 코드 첨부

<title></title>
    <script type="text/javascript">
      window.onload=function(){
        var oBtn=document.getElementById("btn");
        oBtn.onclick=function(){
          alert(1);
        };

        // 网页上所有地方的上的事件都集中到一个按钮身上 IE 专用
        oBtn.setCapture(); // 点击哪里都是弹a
      }
    </script>
  </head>
  <body>
    <input type="button" id="btn" value="按钮" />
  </body>

실제로 페이지의 모든 위치에서 발생하는 이벤트는 한 지점에 집중되어 있습니다. 페이지의 아무 곳이나 클릭하면 setCapture() 기능이 팝업됩니다.

모든 이벤트를 하나의 버튼에 집중하여 처리해보세요! ! 이것은 IE에서만 호환됩니다! !

이제 이전 코드를 수정하는 방법을 살펴보겠습니다. . . .

먼저 모든 문서를 다시 div로 변경합니다. 마우스가 더 빠르게 드래그되므로 div를 드래그하는 것이 더 쉽다는 것을 이전에 말한 것을 기억하여 문서에 이벤트를 추가합니다.

지금은 이 작업을 수행할 필요가 없습니다. 이전 div에 setCapture()를 추가하여 효과를 확인하세요.

<body>
    IE 7 中的文字会被选中 ,
    <br />如果不加return false chrome ff 也会有这样的问题 asdsadad
    <br />
    <div id="div1">
      asdsadad asdsadad asdsadad
    </div>
    asdsadadasdsadadasdsadad
  </body>
<style type="text/css">
      #div1 {
        width: 200px;
        height: 200px;
        background: red;
        position: absolute;
      }
    </style>
<script type="text/javascript">
     // 拖拽空div 低版本的火狐有bug
   window.onload = function() {
    var oDiv = document.getElementById("div1");
    var disX = 0;
    var disY = 0;
    oDiv.onmousedown = function(ev) {
     var oEvent = ev || event;
     disX = oEvent.clientX - oDiv.offsetLeft;
     disY = oEvent.clientY - oDiv.offsetTop;
     oDiv.onmousemove = function(ev) {
      var oEvent = ev || event;
      var oDivLeft = oEvent.clientX - disX;
      var oDivTop = oEvent.clientY - disY;

      oDiv.style.left = oDivLeft + 'px';
      oDiv.style.top = oDivTop + 'px';
     };

     oDiv.onmouseup = function() {
      oDiv.onmousemove = null;
      oDiv.onmouseup = null;
     };
     oDiv.setCapture();
     return false; // 阻止默认事件,解决火狐的bug
    };
   };
  </script>

현재 Div를 드래그할 때 마우스로 드래그하는 문제는 실제로 없습니다. 실제로 setCapture()를 추가하면 전체 웹페이지의 모든 이벤트가 이 div에 수집됩니다.

사실 지금은 이 텍스트가 선택되지 않습니다. 왜? 웹 페이지의 텍스트와 그림의 모든 이벤트가 이제 div에 있으므로 더 이상 이벤트를 얻을 수 없습니다! 그러니 당연히 선택되지 않을 것입니다.

물론 이제 또 다른 질문이 있습니까? ? ? ? 당신은 그 단어들을 선택하려고 할 때 그것을 선택할 수 없다는 것을 알게 될 것입니다.

어떡하지, 이벤트가 div에 집중되어 있습니다. . . !!!!

실제로 이 setCapture()는 잠금과 같습니다. 이제 이벤트가 모두 div에 있습니다. 이제 해당 이벤트는 releaseCapture()입니다.

releaseCapture(); 캡처를 해제하는 것입니다. 실제로 마우스를 올릴 때 추가하면 됩니다.

window.onload = function() {
    var oDiv = document.getElementById("div1");
    var disX = 0;
    var disY = 0;
    oDiv.onmousedown = function(ev) {
     var oEvent = ev || event;
     disX = oEvent.clientX - oDiv.offsetLeft;
     disY = oEvent.clientY - oDiv.offsetTop;
     oDiv.onmousemove = function(ev) {
      var oEvent = ev || event;
      var oDivLeft = oEvent.clientX - disX;
      var oDivTop = oEvent.clientY - disY;

      oDiv.style.left = oDivLeft + 'px';
      oDiv.style.top = oDivTop + 'px';
     };

     oDiv.onmouseup = function() {
      oDiv.onmousemove = null;
      oDiv.onmouseup = null;
      oDiv.releaseCapture();
     };
     oDiv.setCapture();
     return false; // 阻止默认事件,解决火狐的bug
    };
   };
이제 텍스트 선택 문제를 해결할 수 있습니다. 마지막으로 호환 가능하게 만들기 위해 자리를 잡았습니다. 사실 이 setCapture()는 호환되지 않으며 다른 브라우저에 넣는 것은 잘못된 것입니다.

아주 간단합니다. 이번과 마지막에 코드를 병합하면 됩니다. if 판단만 하면 됩니다. 마지막으로 컴파일된 코드를 첨부합니다

<script type="text/javascript">
      window.onload = function() {
        var oDiv = document.getElementById("div1");
        var disX = 0;
        var disY = 0;
        oDiv.onmousedown = function(ev) {
          var oEvent = ev || event;
          disX = oEvent.clientX - oDiv.offsetLeft;
          disY = oEvent.clientY - oDiv.offsetTop;

          if (oDiv.setCapture) {
            oDiv.onmousemove = mouseMove;

            oDiv.onmouseup = mouseUp;

            oDiv.setCapture(); // IE 7 下文字就不会被选中 其实就是文字或图片得不到事件
          } else {
            document.onmousemove = mouseMove;
            document.onmouseup = mouseUp;
          }

          function mouseMove(ev) {
            var oEvent = ev || event;
            var oDivLeft = oEvent.clientX - disX;
            var oDivTop = oEvent.clientY - disY;
            oDiv.style.left = oDivLeft + 'px';
            oDiv.style.top = oDivTop + 'px';
          }

          function mouseUp(ev) {
            this.onmousemove = null;
            this.onmouseup = null;
            if (oDiv.releaseCapture) {
              oDiv.releaseCapture(); // 释放捕获
            }
          }
          return false; // 阻止默认事件,解决火狐的bug
        };
      };
    </script>
자 다 됐어요오(∩_∩)오하하~

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.