HTML5里拖放和dataTransfer的坑

记于:2017.9.27

e.dataTransfer.setData("key",e.target.id);

.......

var data=e.dataTransfer.getData("key");


如上,第一次使用dataTransfer的时候,以为按照JAVA的尿性,第一个参数想当然的当成keyvalue,也就是键值,是自己随意确定,然后再在getData里把keyvalue输入进去,

然后调试的时候就发现,无论如何都无法运行到下一步,JS代码运行到这里就停止了,

后面重新仔细看了一遍资料才发现,第一个参数的值只能是确定是:Text,表示以文本格式获取数据(文本不局限于文字,包括图片之类),或者是URL:以URL格式获取数据

所以只需要根据实际情况修改成这两个中的一个即可。


另外,关于拖放drag中的其它一些坑:

1.调用drop之前一定要先调用dragover,不管你想不想用,并且在处理函数的第一行加上:event.preventDefault();表示允许放下元素

2.只能在dragstart调用函数里执行setData;在drop调用函数了执行getData;这是由操作权限所决定的。

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值