我正在使用 Rails 5.1.6 开发小型网站,上传图片时遇到了一些问题。我需要使用 AJAX 上传,我通过搜索谷歌找到了一些答案,但我还没有成功。我正在使用 Rails 5.1.6 并使用了包含 file_field 的 rails 表单标签。我想上传使用 AJAX 从文件浏览器中选择的图像。
最佳答案
//f.file_field in html.erb will be compiled to <input type='file'>
//you can construct FormData manually, param by param:
var fileInput = document.querySelector('form input[type=file]');
var attachment = fileInput.files[0];
var formData = new FormData();
formData.append('email', 'Your Email');
formData.append('attachment', attachment, 'filename.jpg');
//In jQuery you would send it like this:
$.ajax({
url: "/profile/upload_image",
type: "POST",
beforeSend: function(xhr) {xhr.setRequestHeader('X-CSRF-Token', $('meta[name="csrf-token"]').attr('content'))},
data: "data=" + formData,
success: function(data) {
...
}
});
我也遇到过这种问题。 您可以使用 AJAX 将图像文件的信息发送到您的 rails API,然后您可以上传包含该信息的图像。 要通过 AJAX(例如,从 )上传文件,您需要将参数包装在 FormData 对象中。
关于javascript - 如何在 rails 5.1.6 中使用 AJAX 上传图片,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52940216/