- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有 2 个“可拖动”div 和 2 个“可放置”div。 Draggable1 div 应该被 droppable1 div 接受,依此类推。此功能有效。
如果 draggable1 div 被删除,它会显示另一个具有 id 'hide' 的 'success' div。但是,当我尝试检查两个可拖动对象是否分别被删除时,它不再显示 ID 为“hide2”的新“成功”div。
这是一个 jsfiddle:https://jsfiddle.net/g27t7hey/
<div class="wrap">
<div class="draggables" id="draggable1"></div><br>
<div class="draggables" id="draggable2"></div><br>
</div>
<div class="wrap2">
<div class="droppables" id="droppable1"></div>
<div class="droppables" id="droppable2"></div>
</div>
<div id="hide" style="display:none"></div>
<div id="hide2" style="display:none"></div>
以上是html代码。 fiddle 中提供了 CSS 和 JS 代码。
我想知道为什么它不能同时用于 2 个 div?任何帮助,将不胜感激。
更新:
考虑到 T J 的回答和他更新的代码,我进一步更新了代码以显示我正在寻找的内容:https://jsfiddle.net/g27t7hey/2/
最佳答案
您的代码包含如下语句:
else if (draggableID=='draggable1' && droppableID=='droppable1' && draggableID=='draggable2' && droppableID=='droppable2')
我不确定您在想什么,但是一个变量不能同时有两个值。
draggableID
将是 draggable1
或者是 draggable2
,所以上面的计算结果不会为真。
当您放下一个元素时,回调将执行并且 draggableID
将被设置为被放置元素的 id
。它不包含来自先前函数调用的任何值。
此外,您似乎多次初始化与 draggable
相同的元素。您在上一次初始化中设置的任何选项都将被下一次初始化覆盖。
而且你似乎也有很多重复的代码。
如果我理解正确的话,你想要做的事情可以这样实现:
$(function() {
$('#draggable1, #draggable2').draggable({
containment: 'document',
revert: function(event, ui) {
// return boolean
return !event;
}
});
$('#droppable1,#droppable2').droppable({
tolerance: "touch",
accept: function(draggable) {
var id = $(this).attr('id').split('droppable')[1];
var targetId = draggable.attr('id').split('draggable')[1];
return id == targetId
},
drop: leftDrop
});
function leftDrop(event, ui) {
ui.draggable.appendTo(this).position({
of: $(this),
my: 'center',
at: 'center'
});
var draggableID = ui.draggable.attr("id");
if (draggableID == 'draggable1') $('#hide').show();
if (draggableID == 'draggable2') {
if ($('#draggable1').parent().is('#droppable1')) $('#hide2').show();
}
}
});
html,
body {
margin: 0;
padding: 0;
}
.wrap {
width: 200px;
height: 200px;
background: #e3e3e3;
position: relative;
top: 80px;
margin-left: 0px;
}
.wrap2 {
width: 0px;
height: 0px;
background: #e3e3e3;
position: relative;
top: -300px;
left: 700px;
margin: 0px;
padding: 0px;
opacity: 0.2;
}
.draggables {
width: 20px;
height: 20px;
position: absolute;
}
.droppables {
width: 60px;
height: 60px;
position: absolute;
}
#draggable1 {
background: #003366;
left: 10px;
top: 10px;
}
#draggable2 {
background: #ffff00;
top: 160px;
left: 60px;
}
#droppable1 {
background: #0000FF;
top: 200px;
left: -400px;
}
#droppable2 {
background: #008080;
left: -300px;
top: 200px;
}
#hide {
width: 50px;
height: 10px;
background: #00cc00;
position: absolute;
top: 350px;
}
#hide2 {
width: 50px;
height: 10px;
background: #ff0000;
position: absolute;
top: 400px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://code.jquery.com/ui/1.10.1/jquery-ui.js"></script>
<div class="wrap">
<div class="draggables" id="draggable1"></div>
<br>
<div class="draggables" id="draggable2"></div>
<br>
</div>
<div class="wrap2">
<div class="droppables" id="droppable1"></div>
<div class="droppables" id="droppable2"></div>
</div>
<div id="hide" style="display:none"></div>
<div id="hide2" style="display:none"></div>
已更新 fiddle
关于javascript - Jquery:.show() div 功能未按预期工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33937854/
我找到了 this excellent question and answer它以 x/y(加上 center x/y 和 degrees/radians)开始并计算旋转- 到 x'/y'。这个计算很
全部: 我已经创建了一个 Windows 窗体和一个按钮。在另一个线程中,我试图更改按钮的文本,但它崩溃了;但是如果我尝试更改按钮的颜色,它肯定会成功。我认为如果您更改任何 Windows 窗体控件属
本网站的另一个问题已证实,C 中没有缩写的字面后缀,并且可以执行以下操作: short Number = (short)1; 但是转换它和不这样做有什么区别: short Number = 1; 您使
我有下表: ID (int) EMAIL (varchar(50)) CAMPAIGNID (int) isSubscribe (bit) isActionByUser (bit) 此表存储了用户对事
也就是说,无需触发Javascript事件即可改变的属性,如何保留我手动选中或取消选中的复选框的状态,然后复制到另一个地方? 运行下面的代码片段并选中或取消选中其中的一些,然后点击“复制”: $('#
我在网上找到的所有关于递增指针导致段错误的示例都涉及指针的取消引用 - 如果我只想递增它(例如在 for 循环的末尾)并且我不在乎它是否最终进入无效内存,因为我不会再使用它。例如,在这个程序中,每次迭
我有一个 Spring MVC REST 服务,它使用 XStream 将消息与 XML 相互转换。 有什么方法可以将请求和响应中的 xml(即正文)打印到普通的 log4j 记录器? 在 Contr
做我的任务有一个很大的挑战,那就是做相互依赖的任务我在这张照片中说的。假设我们有两个任务 A 和 B,执行子任务 A1、A2 和 B1、B2,假设任务 B 依赖于 A。 要理想地执行任务 B,您应该执
通过阅读该网站上的几个答案,我了解到 CoInitialize(Ex) should be called by the creator of a thread 。然后,在该线程中运行的任何代码都可以使
这个问题已经困扰我一段时间了。我以前从未真正使用过 ListViews,也没有使用过 FirebaseListAdapters。我想做的就是通过显示 id 和用户位置来启动列表的基础,但由于某种原因,
我很难解释这两个(看似简单)句子的含义: “受检异常由编译器在编译时检查” 这是什么意思?编译器检查是否捕获了所有已检查的异常(在代码中抛出)? “未经检查的异常在运行时检查,而不是编译时” 这句话中
我有一个包含排除子字符串的文本文件,我想迭代该文件以检查并返回不带排除子字符串的输入项。 这里我使用 python 2.4,因此下面的代码可以实现此目的,因为 with open 和 any 不起作用
Spring 的缓存框架能否了解请求上下文的身份验证状态,或者更容易推出自己的缓存解决方案? 最佳答案 尽管我发现这个用例 super 奇怪,但您可以为几乎任何与 SpEL 配合使用的内容设置缓存条件
我有以下函数模板: template HeldAs* duplicate(MostDerived *original, HeldAs *held) { // error checking omi
如果我的应用程序具有设备管理员/设备所有者权限(未获得 root 权限),我如何才能从我的应用程序中终止(或阻止启动)另一个应用程序? 最佳答案 设备所有者可以阻止应用程序: DevicePolicy
非常简单的问题,但我似乎无法让它正常工作。 我有一个组件,其中有一些 XSLT(用于导航)。它通过 XSLT TBB 使用 XSLT Mediator 发布。 发布后
我正在将一个对象拖动到一个可拖放的对象内,该对象也是可拖动的。放置对象后,它会嵌套在可放置对象内。同样,如果我将对象拖到可放置的外部,它就不再嵌套。 但是,如果我经常拖入和拖出可放置对象,则可拖动对象
我正在尝试为按钮和弹出窗口等多个指令实现“取消选择”功能。也就是说,我希望当用户单击不属于指令模板一部分的元素时触发我的函数。目前,我正在使用以下 JQuery 代码: $('body').click
我从 this question 得到了下面的代码,该脚本用于在 Google tasks 上更改 iframe[src="about:blank"] 内的 CSS使用 Chrome 扩展 Tempe
我有一些 @Mock 对象,但没有指定在该对象上调用方法的返回值。该方法返回 int (不是 Integer)。我很惊讶地发现 Mockito 没有抛出 NPE 并返回 0。这是预期的行为吗? 例如:
我是一名优秀的程序员,十分优秀!