Dropzone.js显示存储的图像

时间:2017-10-29 10:58:56

标签: javascript php laravel dropzone.js

我在Laravel应用中使用dropzone.js在我的平台上上传和显示图片。存储工作正常。我将它们保存到数据库和本地文件夹结构中,其中full_size文件夹用于完整图像,icon_size用于那些应该适合作为缩略图(基本上是图像的较小副本)。

我面临的问题是当我尝试显示图像时。这是我的dropzone配置文件:

Dropzone.options.realDropzone = {
  previewsContainer: '#dropzonePreview',
  previewTemplate: document.querySelector('#preview-template').innerHTML,
  addRemoveLinks: true,
  dictRemoveFile: 'Remove',

  // The setting up of the dropzone
  init: function () {

    var myDropzone = this

    $.get('/image', function (data) {

      $.each(data.images, function (key, value) {

        var file = {name: value.original, size: value.size}
        myDropzone.options.addedfile.call(myDropzone, file)
        myDropzone.options.thumbnail.call(myDropzone, file, 'images/icon_size/' + value.server)
        myDropzone.emit('complete', file)
      })
    })

    this.on('removedfile', function (file) {

      $.ajax({
        type: 'POST',
        url: 'image/destroy',
        data: {id: file.name, _token: $('#csrf-token').val()},
        dataType: 'html',
        success: function (data) {
          var rep = JSON.parse(data)
        }
      })

    })
  },
  error: function (file, response) {
    if ($.type(response) === 'string')
      var message = response //dropzone sends it's own error messages in string
    else
      var message = response.message
    file.previewElement.classList.add('dz-error')
    _ref = file.previewElement.querySelectorAll('[data-dz-errormessage]')
    _results = []
    for (_i = 0, _len = _ref.length; _i < _len; _i++) {
      node = _ref[_i]
      _results.push(node.textContent = message)
    }
    return _results
  },
  success: function (file, done) {
  }
}

/image上的Ajax调用工作正常,并返回数据库中的图像实例

enter image description here

但是当每个图像都应该包含在视图中时,它就会出错

enter image description here

我面临的问题是错误,因为我处于/project路线下,因为这些是连接到项目的图像。我不知道如何删除该部分路线,以便直接从public文件夹中提取图片

1 个答案:

答案 0 :(得分:1)

如果有人遇到同样的问题,我通过明确定义提取URL来解决它:

myDropzone.options.thumbnail.call(myDropzone, file, "http://" + window.location.hostname + '/images/icon_size/' + value.server)

http://部分是必填项,否则只是将其附加到现有链接。