php - Dropzone js - 从同一页面拖放文件

标签 php jquery html drag-and-drop dropzone.js

我正在使用Dropzone多个文件拖放功能的插件。当我从笔记本电脑/台式机上传图片时,拖放效果很好。

我的问题是 - 如何将图像从同一页面拖放到 dropzone 中。假设我有一个 dropzone div,并且我有另一个包含多个图像的 div。我想将这些图像拖放到 dropzone 中。

最佳答案

this.on("drop", function(event) {
  var imageUrl = event.dataTransfer.getData('URL');
  var fileName = imageUrl.split('/').pop();

  // set the effectAllowed for the drag item
  event.dataTransfer.effectAllowed = 'copy';

  function getDataUri(url, callback) {
    var image = new Image();

    image.onload = function() {
      var canvas = document.createElement('canvas');
      canvas.width = this.naturalWidth; // or 'width' if you want a special/scaled size
      canvas.height = this.naturalHeight; // or 'height' if you want a special/scaled size

      canvas.getContext('2d').drawImage(this, 0, 0);

      // Get raw image data
      // callback(canvas.toDataURL('image/png').replace(/^data:image\/(png|jpg);base64,/, ''));

      // ... or get as Data URI
      callback(canvas.toDataURL('image/jpeg'));
    };

    image.setAttribute('crossOrigin', 'anonymous');
    image.src = url;
  }

  function dataURItoBlob(dataURI) {
    var byteString,
        mimestring

    if (dataURI.split(',')[0].indexOf('base64') !== -1) {
      byteString = atob(dataURI.split(',')[1])
    } else {
      byteString = decodeURI(dataURI.split(',')[1])
    }

    mimestring = dataURI.split(',')[0].split(':')[1].split(';')[0]

    var content = new Array();
    for (var i = 0; i < byteString.length; i++) {
      content[i] = byteString.charCodeAt(i)
    }

    return new Blob([new Uint8Array(content)], {
      type: mimestring
    });
  }

  getDataUri(imageUrl, function(dataUri) {
    var blob = dataURItoBlob(dataUri);
    blob.name = fileName;
    myDropzone.addFile(blob);
  });
});

http://codepen.io/BartSitek/pen/ZeMGjV

这是我的问题解决方案。数据转换功能是在网上找到的。以下是对实际情况的一些解释:

  • 在“drop”事件期间抓取您正在拖动的图像的 URL
  • 将该 URL 转换为数据 URI 格式
  • 将数据 URI 转换为 Blob
  • 将 Blob 添加到 Dropzone 表单

关于php - Dropzone js - 从同一页面拖放文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30816375/

相关文章:

php - 在 phpmyadmin 中向用户添加文件权限

php - 奇怪的字符而不是撇号出现在 url 变量 (GET) 中

php - CodeIgniter 中的位置文件以便查询数据库

jquery - 水平居中对齐嵌套 ul li

php - 以下邮件功能突然失效

php - Laravel 5 事件处理程序未触发

php - Symfony - 如何添加未嵌入基础对象的表单字段

jquery - jQuery 的 fadeIn() 和 fadeOut() 不适用于 IE 8 吗?

jquery - 如何中止/取消文件读取 - FileReader

javascript - $ ('body' ).on ('blur' ) 在 IE8 中无法正常工作