- objective-c - iOS 5 : Can you override UIAppearance customisations in specific classes?
- iphone - 如何将 CGFontRef 转换为 UIFont?
- ios - 以编程方式关闭标记的信息窗口 google maps iOS
- ios - Xcode 5 - 尝试验证存档时出现 "No application records were found"
这两个属性之间的关系似乎是一些困惑的根源。基于阅读 the MDN site和 MSDN我以为我已经弄明白了,但现在我不确定...
我想当一个元素被拖动时,你可以指定允许发生在它身上的事情(即它可以被移动、复制、链接到 effectAllowed
常量之一)。这是 effectAllowed
属性。
不同的放置目标做不同的事情,所以当你拖过另一个元素时,它可以控制在放置时发生哪种“效果”,这就是“dropEffect”属性。所以我建立了一个简单的例子来验证这个理论。
$("[draggable='true']").on("dragstart", function(e) {
var dt = e.originalEvent.dataTransfer;
dt.effectAllowed = "copyMove";
dt.setData("text/plain", "Foo");
});
$("#dropZoneCopy").on("dragover", function(e) {
var dt = e.originalEvent.dataTransfer;
dt.dropEffect = "copy";
e.preventDefault();
});
$("#dropZoneMove").on("dragover", function(e) {
var dt = e.originalEvent.dataTransfer;
dt.dropEffect = "move";
e.preventDefault();
});
我有一个用户可以拖动的框 - 允许的效果是“copyMove”。我有一个设置 dropEffect
复制的盒子,一旦它设置 dropEffect
移动。我期望的是,当用户拖过“复制框”时,光标会改变以指示将发生复制,当我拖过“移动框”时,光标会改变以指示移动...
只有 Chrome 的行为符合我的预期。这是因为其他浏览器错误还是因为我不了解规范。正确吗?
更新摆弄这个的更多信息。
在 Firefox 和 Chrome 中,如果您有一个 dragsource 指示 effectAllowed 是“copy”,而一个 dropzone 表示 dropEffect 是“move”,那么即使您取消事件,您也无法放置在 drop zone 上。我认为 dropEffect 对阅读 ondrop 以了解要做什么很有用,但它在 Chrome 上不可用,dropEffect 不会出现在放置处理程序上,例如尝试读取 dataTransfer.dropEffect 会说 dropEffect 是“无”,即使您将其设置为 dragover。如上所述设置 dropEffect 确实会影响光标的显示方式。
在 Firefox 上,dropEffect 在 dragover 上设置后确实会在 dropzone 上生效,但它不会影响鼠标光标的显示。在 Firefox windows 上按下 ctrl 键会影响鼠标的显示,但不会影响 dropEffect 属性。
规范显示源可以监听 dragend 事件以查看发生了什么。它应该查看此事件中的 dropEffect。 Chrome、Mozilla 和 Safari 的工作方式与您希望的一样,拖放效果出现在 dragend 事件中。在 IE 中,如果允许的效果是一个简单的值,例如“复制”然后任何成功的放置都会导致此值显示为 dragend 上的 dropEffect。如果 effectAllowed 是一个像 copyMove 这样的复合值,并且您试图通过设置 dropEffect 在 dragover 上选择“移动”,那么您就不走运了,它将在 dragend 的源代码中以 dropEffect = "none"的形式出现。你被一个光标和一个 dropEffect 困住了,如果那个效果是一个简单的值,那就是在 dragstart 上设置的 effectAllowed 。有趣的是,当您至少从 IE11 拖入 native 应用程序时(我之前假设),它似乎确实会出现 dropEffect。
其他注意事项
在 mac 上的 Safari 上 - effectAllowed 不能以编程方式设置,因此任何设置的 dropEffect 都是有效的。当您按下 cmd 键时,effectAllowed 变为“移动”,而当您按下 alt 键时,effectAllowed 变为“复制”。此后,如果 dropEffect 不是这些 effectAlloweds 之一,浏览器将不允许放置。
更多信息我一直在花一些空闲时间在 HTML5 拖放库上工作,我为此在文档中写了很多关于这个和其他问题的内容,如果您有兴趣,请看一看 the project
最佳答案
看看https://web.dev/drag-and-drop/
function handleDrop(e) {
e.stopPropagation(); // Stops some browsers from redirecting.
e.preventDefault();
var files = e.dataTransfer.files;
for (var i = 0, f; f = files[i]; i++) {
// Read the File objects in this FileList.
}
}
关于javascript - HTML5 拖放效果允许和 dropEffect,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20471273/
我在这里有一个我想要做的事情的例子:http://jsbin.com/OwoYAlEQ/1/edit 这是我的 HTML: person one person two person three per
我想知道是否有人知道是否有一个预先制定的解决方案:我在 ASP.net 网站上有一个列表,我希望用户能够通过拖放对列表进行重新排序。此外,我希望有第二个列表,用户可以将第一个列表中的项目拖到其中。 到
我想知道是否有人知道是否有一个预先制定的解决方案:我在 ASP.net 网站上有一个列表,我希望用户能够通过拖放对列表进行重新排序。此外,我希望有第二个列表,用户可以将第一个列表中的项目拖到其中。 到
我在我的 Web 应用程序中使用 Ajax ControlToolkit 中的 ModalPopupExtender。我将其 Drag 属性设置为 true,但是当我拖动弹出面板并将其放到新位置时,它
所以,基于this answer ,我有一组可以拖放并卡入到位的 div。唯一的问题是,可拖动的 div 具有不同的高度,我需要它们始终捕捉到目标的底部,而不是顶部。 您可以在this JsFiddl
我一直在使用 Bea 的解决方案 here一段时间后发现它非常有帮助。现在我遇到的问题是,当我将项目拖放到另一个 ListView 控件中或拖放到另一个 ListView 控件中,并且我想在拖动“期间
我试图在使用 QTreeWidget.setItemWidget() 重新父级(拖放)后将小部件放入 QTreeWidgetItem 但是,如果编译以下代码,结果是 QTreeWidgetItem 内
这是场景,我使用的是prototype和scriptaculous,但我相信jquery也会有同样的问题。我在相对定位的 div 中有一个可拖动图像的列表。问题是我无法将图像拖出父 div...好吧.
我正在使用一个普通(Bootstrap)表,我想在其中包含可排序的行。我正在使用 Angular CDK (DragDropModule) 来实现排序/排序。但是,当拖动行时,它会扭曲宽度,因为 cd
我正在尝试在我的 UICollectionView 中实现拖放机制,这与在快捷方式应用程序中重新排序快捷方式的组件非常相似。 截至目前,行为是当您开始拖动时,会留下一个透明的单元格 View ,而另一
我有以下 Jquery UI 拖放 jsfiddle https://jsfiddle.net/zoojsfiddle/ud96jdcp/ 具有
我希望创建一个基于网络的“公告板”,可以这么说,用户可以在其中创建/删除/拖放“图钉”,而不允许重叠“图钉”。 这是一个图表,应该有助于说明我正在尝试创建的内容: 'pins' 可能已创建双击;他们会
我是一名优秀的程序员,十分优秀!