javascript - 如何将项目拖放到外部容器?

标签 javascript jquery angularjs jquery-ui-sortable

基本上,我有以下标记:

<script>
    $(function() {
        $('.box').on('mousedown', function(e) {
            console.log(e);
        });
    });
</script>

<body ng-controller="MainCtrl">
    <ul ui-sortable="sortableOptions" ng-model="list">
        <li draggable ng-repeat="item in list">Item: {{item}}</li>
    </ul>
    <div class="boxes">
        Drop to external area: <br/><br/>
        <div class="box" style="background: red;"></div>
        <div class="box" style="background: yellow;"></div>
        <div class="box" style="background: orange;"></div>
    </div>
</body>

fiddle :http://plnkr.co/edit/xKw6sSbymA5M8R2v4OGF?p=preview

现在,我希望能够将列表中的项目拖放到该“外部”容器中。

当用户将项目“拖放到”任何彩色区域时,我想知道刚刚发生的事件以及哪个元素受到影响

已尝试监听每个 .box 元素上的 mousedown/mouseup 事件,但它无法按预期工作。

最佳答案

您使用的库是排序库。您需要为此使用拖放库。

例如,您可以使用 https://github.com/codef0rmer/angular-dragdrop

请参阅文档以了解所有可用的事件回调。

直接复制示例代码片段(用于引用检查 here ),

HTML:

<ul class="thumbnails">
    <li style='margin-left:10px;' ng-repeat="item in list1">
        <div class="btn" 
             data-drop="true" 
             ng-model='list1' 
             jqyoui-droppable="{index: {{$index}}}">

            <div class="btn btn-info" 
                 ng-show="item.title" 
                 data-drag="{{item.drag}}" 
                 data-jqyoui-options="{revert: 'invalid'}" 
                 ng-model="list1" 
                 jqyoui-draggable="{index: {{$index}},placeholder:true,animate:true}">
                {{item.title}}
            </div>

        </div>
    </li>
</ul>

<div class="container form-inline" style="text-align: center;">
    <div class="btn"
         ng-repeat="item in list2 | orderBy : 'title'" 
         data-drop="true" 
         ng-model='list2' 
         jqyoui-droppable="{index: {{$index}}, applyFilter: 'filterIt'}">

        <div class="btn btn-info" 
             data-drag="{{item.drag}}" 
             data-jqyoui-options="{revert: 'invalid'}" 
             ng-model="list2" 
             jqyoui-draggable="{index: {{$index}},animate:true, applyFilter: 'filterIt'}" 
             ng-hide="!item.title">
            {{item.title}}
        </div>

    </div>
</div>

Controller :

App.controller('YourCtrl', function($scope, $filter) {
    $scope.filterIt = function() {
        return $filter('orderBy')($scope.list2, 'title');
    };
    $scope.list1 = [];
    $scope.list2 = [
        { 'title': 'Item 3', 'drag': true },
        { 'title': 'Item 2', 'drag': true },
        { 'title': 'Item 1', 'drag': true },
        { 'title': 'Item 4', 'drag': true }
    ];
    angular.forEach($scope.list2, function(val, key) {
        $scope.list1.push({});
    });
});

希望这能解决您的问题。

关于javascript - 如何将项目拖放到外部容器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38358608/

相关文章:

javascript - JavaScript 事件循环和 Node.js 事件循环有什么区别?

javascript - 如何使用javascript获取手机的宽度

javascript - 在javascript中创建一个 "calculation form"

javascript - 如何在单击时使用带有 javascript 的 svg 内嵌动画?

javascript - 如何在 AngularJs 中循环

angularjs - Angular 路由 : resolve vs. Controller

javascript - 具有键盘导航行为的 Jquery 自定义画廊

Javascript 灯箱作为分布式代码片段的一部分

javascript - 使用 .load() 缓慢加载内容 - jQuery

javascript - JS自定义进度条