首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >jQuery UI --追加类,使其可拖放

jQuery UI --追加类,使其可拖放
EN

Stack Overflow用户
提问于 2016-02-06 10:32:38
回答 1查看 194关注 0票数 1

你好!

我刚从jQuery UI开始,所以我已经被一些东西困住了.

我正在尝试做一个网络程序,它允许用户制作一个平面图。它具有拖放功能。

它有一个菜单,其中有几个可以被拖动的项目。问题是,当它被拖来拖去时,菜单中的项目就消失了(因为它被拖来拖去)。所以我试着用下面的代码来解决这个问题:

jQuery:

代码语言:javascript
代码运行次数:0
运行
复制
$('.notActive').draggable({ //.notActive is an item in the menu
    stop: function(){
        $(this).removeClass('notActive'); 
        $(this).addClass('active'); //make it an active item
        $('#menu').append($('<div class="item notActive">Furniture</div>'));
        //this creates a new item in the menu
    }
});

每个item都有类.notActive,因为它没有被拖动。当用户拖动它时,它会移除该类并接收类.active。因此,当它被拖动时,它会在#menu中创建一个带有类.notActive的新元素。问题是,新创建的(附加(?))菜单中的项不是.draggable(),即使它有类.notActive

为什么会这样呢?如何创建一个新实例,即.draggable()

为语法错误道歉,我是荷兰人。

编辑

这里是Fiddle:https://jsfiddle.net/8tpy7x3e/

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-02-06 10:51:16

在添加到菜单中的新项上,您没有显式地调用draggable

像这样的东西会有用的:

代码语言:javascript
代码运行次数:0
运行
复制
$('.notActive').draggable({ //.notActive is an item in the menu
  stop: function(){
    $(this).removeClass('notActive'); 
    $(this).addClass('active'); //make it an active item
    //Create a new object
    var newItem = $('<div class="item notActive">Furniture</div>');
    //Make the new item "draggable" and add it to the menu
    newItem.draggable();
    $('#menu').append(newItem);
    //this creates a new item in the menu
  }
});

小提琴例子

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35239977

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档