我在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调用工作正常,并返回数据库中的图像实例
但是当每个图像都应该包含在视图中时,它就会出错
我面临的问题是错误,因为我处于/project
路线下,因为这些是连接到项目的图像。我不知道如何删除该部分路线,以便直接从public
文件夹中提取图片
答案 0 :(得分:1)
如果有人遇到同样的问题,我通过明确定义提取URL来解决它:
myDropzone.options.thumbnail.call(myDropzone, file, "http://" + window.location.hostname + '/images/icon_size/' + value.server)
http://
部分是必填项,否则只是将其附加到现有链接。