7

我是 Angular 的新手,并且一直在尝试创建一个指令,它将元素上的位置绑定到模型 - 在用户拖动它之后。我发现了另一个 Stack Overflow 问题,它为一个简单的对象解决了这个问题:

Angularjs指令属性绑定左上角拖动后

myApp.directive('draggable', function () {
    return {
        restrict: 'A',
        link: function (scope, element, attrs) {
            element.draggable({
                cursor: "move",
                stop: function (event, ui) {
                    scope[attrs.xpos] = ui.position.left;
                    scope[attrs.ypos] = ui.position.top;
                    scope.$apply();
                }
            });
        }
    };
});

请参阅此处的小提琴解决方案:http: //jsfiddle.net/mrajcok/5Mzda/

现在,我现在正试图让它与更复杂的对象和 一起工作ng-repeat,但似乎无法弄清楚为什么它不起作用。

这是我的 HTML:

<div ng-controller="MyCtrl">
  <div ng-repeat="position in positions">
      <input type="number" ng-model="position.divleft"/>
      <input type="number" ng-model="position.divtop"/>
      <p draggable class="example" ng-style="{left: position.divleft, top: position.divtop}" xpos="position.divleft" ypos="position.divtop">Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.</p>
  </div>
</div>

这是JS:

var myApp = angular.module('myApp', []);

function MyCtrl($scope) {
  $scope.positions = [
      {"divtop": 80,
       "divleft": 200
      },
      {"divtop": 100,
       "divleft": 250
      }
  ];
};

myApp.directive('draggable', function () {
    return {
        restrict: 'A',
        link: function (scope, element, attrs) {
            element.draggable({
                cursor: "move",
                stop: function (event, ui) {
                    scope[attrs.xpos] = ui.position.left;
                    scope[attrs.ypos] = ui.position.top;
                    scope.$apply();
                }
            });
        }
    };
});

这是小提琴:

http://jsfiddle.net/5Mzda/19/

我似乎看不出代码有什么问题。将不胜感激任何帮助!

更新

我在原始问题中更仔细地阅读了评论,看起来像是在使用$eval作品:

myApp.directive('draggable', function () {
    return {
        restrict: 'A',
        link: function (scope, element, attrs) {
            element.draggable({
                cursor: "move",
                stop: function (event, ui) {
                    scope.$eval(attrs.xpos + '=' + ui.position.left);
                    scope.$eval(attrs.ypos + '=' + ui.position.top);
                    scope.$apply();
                }
            });
        }
    };
});

不确定是否有更优雅的方法可以做到这一点,但现在看来绑定工作正常!

4

1 回答 1

7

这看起来不错。

您需要在角度框架中执行所有与角度相关的表达式。如果是从事件处理程序外部调用的 dom 事件处理程序和方法,您需要使用$apply以角度执行它们,这将执行表达式,然后调用$digest进而调用附加的手表。

您唯一需要做的改变是将语句移到里面$apply()

scope.$apply(function(){
    scope.$eval(attrs.xpos + '=' + ui.position.left);
    scope.$eval(attrs.ypos + '=' + ui.position.top);
});

演示:小提琴

于 2013-03-18T07:32:08.383 回答