将对象拖到可排序列表中 - AngularJS

2024-05-26

Problem:

我正在尝试从 jQuery 重新创建 Draggable + Sortable 功能,但无法将删除的元素放入我的对象数组中。

我想拖一个$.draggable()按钮进入$.sortable()列表。我希望按钮代表一个具有属性的对象(可以是关联数组,也可以是对象本身),当我将其放入列表中时,我希望它将自己放入数组中放置的位置。


只是为了清楚起见,我有一系列潜在的左侧菜单中的对象。右边我用的是$http调用我的 API 来检索包含所有字段的表单$scope。我想要那个潜在的物体(比如textarea) 被拖放到该表单的字段中所拖放的位置。

jquery 位很简​​单,但该位置的对象不存在$scope数组是问题所在。


我尝试过的:

我很接近混合梳理ui-sortable and $.draggable指令包装器,但我的代码运行得不太好。


例子:

  • KnockoutJS 示例 https://jsfiddle.net/cuhuak/4CHDZ/
  • jQuery 演示 http://jqueryui.com/draggable/#sortable

更新1:

我已经取得了进步ui-sortablelike 指令与包装指令相结合$.draggable(),有点丑,但有效。

更新2:

我现在可以使用它,但我从 jquery 获取索引并使用 PHP 将其切片到该位置,然后重新加载整个列表。谈论跛脚一定有更好的方法。

更新3:

这是一个工作example http://clouddueling.github.io/angular-common适合任何人的应用程序的模块化。


没有角度魔法可以帮助您找到新元素或移动元素的位置,但使用 jQuery 很容易做到。我创建了一个在指令中包装可排序和可拖动的 jQueryUI-demo 示例:

http://plnkr.co/edit/aSOlqR0UwBOXgpQSFKOH?p=preview http://plnkr.co/edit/aSOlqR0UwBOXgpQSFKOH?p=preview

<ul>
  <li my-draggable="#sortable" class="ui-state-highlight">Drag me down</li>
</ul>

<ul my-sortable id="sortable">
  <li class="ui-state-default" ng-repeat="item in items">{{item.name}}</li>
</ul>

我的价值my-draggable是对应的idmy-sortable-元素。 my-draggable 在其他方面非常简单:

app.directive('myDraggable',function(){

  return {
    link:function(scope,el,attrs){
      el.draggable({
        connectToSortable: attrs.myDraggable,
        helper: "clone",
        revert: "invalid"
    });
    el.disableSelection();
    }
  }
})

In my-sortable我听deactivate指示元素已被删除的事件。from是数组中作为 ng-repeat 源的元素的位置。 ng-repeat 为每个元素创建一个子作用域,并使用 $index 变量指示当前元素在数组中的位置。如果 $index 未定义,我知道它是一个新元素(可能是确定这一点的更好方法,但它适用于本示例)。to是该项目的新位置。如果移动了现有元素,则 $ 发出 'my-sorted' 事件;如果添加新项目,则发出 'my-created' 事件。

app.directive('mySortable',function(){
  return {
    link:function(scope,el,attrs){
      el.sortable({
        revert: true
      });
      el.disableSelection();

      el.on( "sortdeactivate", function( event, ui ) { 
        var from = angular.element(ui.item).scope().$index;
        var to = el.children().index(ui.item);
        if(to>=0){
          scope.$apply(function(){
            if(from>=0){
              scope.$emit('my-sorted', {from:from,to:to});
            }else{
              scope.$emit('my-created', {to:to, name:ui.item.text()});
              ui.item.remove();
            }
          })
        }
      } );
    }
  }
})

在控制器中,我创建项目数组并监听事件:

$scope.items = [
  {name:'Item 1'},
  {name:'Item 2'},
  {name:'Item 3'},
  {name:'Item 4'},
];

$scope.$on('my-sorted',function(ev,val){
  // rearrange $scope.items
  $scope.items.splice(val.to, 0, $scope.items.splice(val.from, 1)[0]);
})

$scope.$on('my-created',function(ev,val){
  // create new item at position 
  $scope.items.splice(val.to, 0,
    {name:'#'+($scope.items.length+1)+': '+val.name});
})

正如您所看到的,当您添加或移动元素时,范围中的模型会更新。

这些指令不是很通用 - 您可能需要进行一些调整才能使它们与您的应用程序一起工作。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

将对象拖到可排序列表中 - AngularJS 的相关文章

随机推荐