在 HTML5 中拖放 Javascript

标签 javascript jquery html drag-and-drop jquery-events

尝试在 HTML5 中做一个简单的拖放示例 - 但是当我将图像拖放到 div 元素中时,出现以下错误。

Uncaught TypeError: Cannot set property 'innerHTML' of null

所以我假设错误消息意味着 dragElement 为空。我不明白为什么,因为我在 dragstart 事件中将它设置为 img 元素的 HTML。

有人知道怎么做吗?

var dragElement = null;

$('#x').bind('dragstart', function (e) {
    dragElement = this;
    e.dataTransfer.effectAllowed = 'move';
    e.dataTransfer.setData('text/html', this.innerHTML);
});

$('#drop-box').bind('dragover', function (e) {
    e.preventDefault();
    return false;
});

$('#drop-box').bind('drop', function (e) {
    e.preventDefault();
    if (e.stopPropagation) {
        e.stopPropagation();
    }

    if (dragElement != this) {
        dragElement.innerHTML = this.innerHTML;
        this.innerHTML = e.originalEvent.dataTransfer.getData('text/html');
    }

    return false;
});

最佳答案

dataTransfer 是原始事件对象的一部分,而不是 jQuery 对象。使用 e.originalEvent 代替:http://jsfiddle.net/KWut6/ .

 e.originalEvent.dataTransfer ...

HTML

<image src="http://lorempixum.com/100/100/" draggable="true" id="x">
<div id="drop-box">a</div>

JavaScript

var dragElement = null;

$('#x').bind('dragstart', function (e) {
    dragElement = this;
    e.originalEvent.dataTransfer.effectAllowed = 'move';
    e.originalEvent.dataTransfer.setData('text/html', this.innerHTML);
});

$('#drop-box').bind('dragover', function (e) {
    e.preventDefault();
    return false;
});

$('#drop-box').bind('drop', function (e) {
    e.preventDefault();
    if (e.stopPropagation) {
        e.stopPropagation();
    }

    if (dragElement != this) {
        dragElement.innerHTML = this.innerHTML;
        this.innerHTML = e.originalEvent.dataTransfer.getData('text/html');
    }

    return false;
});

关于在 HTML5 中拖放 Javascript,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8189918/

相关文章:

jquery - jquery 新手 - 淡出对我不起作用

javascript - 使用 jquery 加载目标 div 中的内容

html - 使用 Bootstrap 3 将图标放在提交按钮内

javascript - 我使用这个 Javascript 代码,它完成了工作,但我觉得它可以更短

jquery - 如何使用 Ajax 获取在输入字段中输入的内容?

javascript - map() 作为 React 中 setState() 的回调,奇怪地运行条件两次

javascript - 点击注册按钮后生成一个随机数

javascript - CSS 在移动设备上消失

javascript - 使用 angularjs 在复选框选中/取消选中时打印不同的文本

javascript - 如何在 jQuery 中定义选择一个元素?