美文网首页
JS中的dataTransfer对象

JS中的dataTransfer对象

作者: alan_yeh | 来源:发表于2018-07-10 00:21 被阅读0次

在进行拖放操作的时候,dataTransfer对象可以用来保存被拖动的数据。它可以保存一项或多项数据、一种或多数数据类型。通谷一点讲,就是可以通过它来传输被拖动的数据,以便在拖拽结束的时候,对数据进行其他的操作。

在项目拖动的开始事件(ondragstart)的时候,可以对dataTransfer进行设值操作(setData)。

document.getElementById('source').ondragstart = function (event) {
    event.dataTransfer.setData('some-key', 'some-value');
};

在项目拖动结束的时候,可以获取dataTransfer对象里的值。

document.getElementById('target').ondrop = function(event){
    event.preventDefault(); // 拖动的默认处理方式是在新窗口打开,所以阻止其执行
    let value = event.dataTransfer.getData('some-key');
    // some-value
}

在其它的事件(如ondragoverondragleave等),是无法获取dataTransfer里面的值了。这是由于W3C要求对dataTransfer里的值进行保护[参考]。因此,如果需要在这些事件里获取数据,只能通过一个全局变量等其它方式来实现了。

相关文章

  • JS中的dataTransfer对象

    在进行拖放操作的时候,dataTransfer对象可以用来保存被拖动的数据。它可以保存一项或多项数据、一种或多数数...

  • 小测-dom-41

    小测-dom-41 知识点: 拖拽 DataTransfer拖拽献祭中的黑山羊-DataTransfer对象MDN...

  • 拖拽事件的dataTransfer

    dataTransfer 贯穿于整个拖拽生命的承载对象 setDate### dataTransfer...

  • 拖拽事件的dataTransfer

    dataTransfer 贯穿于整个拖拽生命的承载对象 setDate dataTransfer.setData(...

  • h5的拖动drag&drop

    DataTransfer对象:退拽对象用来传递的媒介,使用一般为Event.dataTransfer。 dragg...

  • 前端文件的下载

    file对象,blob对象,filreader对象,fileList和dataTransfer。生成下载链接,a....

  • JS 对象

    JS对象 JS对象的意义和声明 在JS中,对象(OBJECT)是JS语言的核心概念,也是最重要的数据类型。在JS中...

  • js 对象和jquery对象的比较

    1、js 对象和jquery对象的区别 jquery对象是js中的new Object()生成的普通对象 2、js...

  • jQuery前端框架--笔记

    1,JS对象和jQuery对象的区别 jQuery就是JS中的new Object生成的普通对象。 2,JS对象和...

  • JavaScript中的Object对象

    JavaScript中的Object对象,是JS中所有对象的基类,也就是说JS中的所有对象都是由Object对象衍...

网友评论

      本文标题:JS中的dataTransfer对象

      本文链接:https://www.haomeiwen.com/subject/bbpxpftx.html