- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我试图让我的拖放操作在 JavaScript 中正常工作,而不必显式扫描父元素或其他 ID、类循环和其他 hacky magic。
现在当我将元素池中的一个元素拖到灰色区域时,该元素被复制到拖放区(到目前为止一切都是正确的)。我基本上是复制拖动元素的 HTML,清除拖放区(目标)并将新元素添加到其中。
当您在放置区中已经有一些子元素并将其拖到子元素上时,问题就开始了。然后 drop 事件中的目标是子元素,而不是事件附加到的 div。这会导致被拖动的元素清除并将自身复制到子元素中,而不是放置容器中。
预期的结果应该是,无论是将它放在子节点上还是直接放在主放置容器上,目标应该始终是父节点,因为我使用的是事件捕获模式。
这是我在 JS Fiddle 中的示例代码。我正在使用带有捕获的事件监听器,但它似乎无论如何都在进行冒泡阶段并忽略捕获阶段。为什么?
执行此操作的正确方法是什么?
function onDrag(ev) {
var el = ev.target;
//console.log("Drag: " + ev.target.outerHTML)
ev.dataTransfer.setData('text/html', ev.target.outerHTML);
}
function onContainerOver(ev) {
ev.preventDefault();
ev.dataTransfer.dropEffect = "move"
}
function onContainerDrop(ev) {
ev.preventDefault();
//console.log("Drop: " + ev.dataTransfer.getData("text/html"))
ev.target.innerHTML = ev.dataTransfer.getData("text/html");
}
document.getElementById('target').addEventListener('drop', onContainerDrop, true); // This should not bubble, but it does. Target is always the child first rather than the element where the event listener resides. Why???
#list {}
.el {
padding: 5px;
margin: 10px;
border: solid 1px black;
background-color: #86d4ff;
cursor: move;
line-height: 1em;
text-align: left;
}
#target {
min-height: 200px;
width: 100%;
background-color: #ffdea6;
border: 1px dashed gray;
text-align: center;
line-height: 100px;
}
<div id="list">
<div class="el" draggable="true" ondragstart="onDrag(event)">ELEMENT A</div>
<div class="el" draggable="true" ondragstart="onDrag(event)">ELEMENT B</div>
<div class="el" draggable="true" ondragstart="onDrag(event)">ELEMENT C</div>
</div>
<div id="target" ondragover="onContainerOver(event)">
Drop Here
</div>
最佳答案
当您将任何东西放在子元素上或子元素上发生任何事件时,事件目标 始终是子元素,因为那是事件发生的地方。这就是目标。
┌─────────────────────────────────────┐
│ ┌────────────────────────┐ │
│ │ Child [Target] │ │
│ └────────────────────────┘ │
│ Parent │
└─────────────────────────────────────┘
然后这个事件作为子元素作为Target和CurrentTarget传递给子元素的事件处理程序
┌─────────────────────────────────────┐
│ ┌───────────────────────────────┐ │
│ │ Child [Target][CurrentTarget] │ │
│ └───────────────────────────────┘ │
│ Parent Element │
└─────────────────────────────────────┘
然后这个事件作为Target的子元素和作为CurrentTarget的父元素传递给父元素的事件处理程序
┌─────────────────────────────────────┐
│ ┌───────────────────────────────┐ │
│ │ Child [Target] │ │
│ └───────────────────────────────┘ │
│ Parent [CurrentTarget] │
└─────────────────────────────────────┘
然后事件以相同的方式依次传递给 dom 树中较高的元素,直到到达顶级元素或任何事件处理程序通过调用 event.stopPropagation( )
那么当您创建事件处理程序并将第三个参数 useCapture 作为 true 传递时会发生什么。
parentElement.addEventListener('click', myClickHandler, true);
在这种情况下,事件首先传递给父元素 [currentTarget:Parent],然后传递给子元素 [currentTarget:Child],但一如既往, 事件目标始终是子元素,因为这是触发事件的地方。
关于当前目标 this MDN WebDocs page说,
Identifies the current target for the event, as the event traverses the DOM. It always refers to the element to which the event handler has been attached, as opposed to event.target which identifies the element on which the event occurred.
关于javascript - 即使使用捕获阶段,OnDrop 事件目标也是子对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47811676/
我的一位教授给了我们一些考试练习题,其中一个问题类似于下面(伪代码): a.setColor(blue); b.setColor(red); a = b; b.setColor(purple); b
我似乎经常使用这个测试 if( object && object !== "null" && object !== "undefined" ){ doSomething(); } 在对象上,我
C# Object/object 是值类型还是引用类型? 我检查过它们可以保留引用,但是这个引用不能用于更改对象。 using System; class MyClass { public s
我在通过 AJAX 发送 json 时遇到问题。 var data = [{"name": "Will", "surname": "Smith", "age": "40"},{"name": "Wil
当我尝试访问我的 View 中的对象 {{result}} 时(我从 Express js 服务器发送该对象),它只显示 [object][object]有谁知道如何获取 JSON 格式的值吗? 这是
我有不同类型的数据(可能是字符串、整数......)。这是一个简单的例子: public static void main(String[] args) { before("one"); }
嗨,我是 json 和 javascript 的新手。 我在这个网站找到了使用json数据作为表格的方法。 我很好奇为什么当我尝试使用 json 数据作为表时,我得到 [Object,Object]
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我听别人说 null == object 比 object == null check 例如: void m1(Object obj ) { if(null == obj) // Is thi
Match 对象 提供了对正则表达式匹配的只读属性的访问。 说明 Match 对象只能通过 RegExp 对象的 Execute 方法来创建,该方法实际上返回了 Match 对象的集合。所有的
Class 对象 使用 Class 语句创建的对象。提供了对类的各种事件的访问。 说明 不允许显式地将一个变量声明为 Class 类型。在 VBScript 的上下文中,“类对象”一词指的是用
Folder 对象 提供对文件夹所有属性的访问。 说明 以下代码举例说明如何获得 Folder 对象并查看它的属性: Function ShowDateCreated(f
File 对象 提供对文件的所有属性的访问。 说明 以下代码举例说明如何获得一个 File 对象并查看它的属性: Function ShowDateCreated(fil
Drive 对象 提供对磁盘驱动器或网络共享的属性的访问。 说明 以下代码举例说明如何使用 Drive 对象访问驱动器的属性: Function ShowFreeSpac
FileSystemObject 对象 提供对计算机文件系统的访问。 说明 以下代码举例说明如何使用 FileSystemObject 对象返回一个 TextStream 对象,此对象可以被读
我是 javascript OOP 的新手,我认为这是一个相对基本的问题,但我无法通过搜索网络找到任何帮助。我是否遗漏了什么,或者我只是以错误的方式解决了这个问题? 这是我的示例代码: functio
我可以很容易地创造出很多不同的对象。例如像这样: var myObject = { myFunction: function () { return ""; } };
function Person(fname, lname) { this.fname = fname, this.lname = lname, this.getName = function()
任何人都可以向我解释为什么下面的代码给出 (object, Object) 吗? (console.log(dope) 给出了它应该的内容,但在 JSON.stringify 和 JSON.parse
我正在尝试完成散点图 exercise来自免费代码营。然而,我现在只自己学习了 d3 几个小时,在遵循 lynda.com 的教程后,我一直在尝试确定如何在工具提示中显示特定数据。 This code
我是一名优秀的程序员,十分优秀!