首頁 >web前端 >js教程 >angularjs建立彈出框實作拖曳效果_AngularJS

angularjs建立彈出框實作拖曳效果_AngularJS

WBOY
WBOY原創
2016-05-16 15:21:271160瀏覽

本文實例介紹了angularjs創建彈出框實現拖曳效果的相關程式碼,專案中需要將angular-ui-bootstrap中用到的彈出框,使之可拖曳,分享給大家供大家參考,具體內容如下

運作效果圖:

由於原始檔中沒有實現,需要自行實作指令,以下即為該指令,親測可以實現。

.directive('draggable', ['$document', function($document) {
        return function(scope, element, attr) {
        var startX = 0, startY = 0, x = 0, y = 0;
        element= angular.element(document.getElementsByClassName("modal-dialog")); 
        element.css({
          position: 'relative',
          cursor: 'move'
        });

        element.on('mousedown', function(event) {
          // Prevent default dragging of selected content
          event.preventDefault();
          startX = event.pageX - x;
          startY = event.pageY - y;
          $document.on('mousemove', mousemove);
          $document.on('mouseup', mouseup);
        });

        function mousemove(event) {
          y = event.pageY - startY;
          x = event.pageX - startX;
          element.css({
          top: y + 'px',
          left: x + 'px'
          });
        }

        function mouseup() {
          $document.off('mousemove', mousemove);
          $document.off('mouseup', mouseup);
        }
        };
  }]);

以上就是本文的全部內容,希望對大家的學習有所幫助。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn