为了账号安全,请及时绑定邮箱和手机立即绑定

没有表格的文件上传

没有表格的文件上传

不使用任何形式,我可以<input type="file">使用jQuery使用POST方法将文件从发送到“ upload.php”。输入标签不在任何表单标签内。它单独站立。所以我不想使用jQuery插件,例如“ ajaxForm”或“ ajaxSubmit”。
查看完整描述

3 回答

?
不负相思意

TA贡献1777条经验 获得超10个赞

您可以使用FormData通过POST请求提交数据。这是一个简单的示例:


var myFormData = new FormData();

myFormData.append('pictureFile', pictureInput.files[0]);


$.ajax({

  url: 'upload.php',

  type: 'POST',

  processData: false, // important

  contentType: false, // important

  dataType : 'json',

  data: myFormData

});

只要知道请求设置(例如url,方法和参数数据),就不必使用表单来发出ajax请求。


查看完整回答
反对 回复 2019-11-12
?
饮歌长啸

TA贡献1951条经验 获得超3个赞

此处的所有答案仍在使用FormData API。就像"multipart/form-data"没有表格的上传一样。您还可以使用以下命令将文件作为内容直接上传到POST请求的正文中xmlHttpRequest:


var xmlHttpRequest = new XMLHttpRequest();


var file = ...file handle...

var fileName = ...file name...

var target = ...target...

var mimeType = ...mime type...


xmlHttpRequest.open('POST', target, true);

xmlHttpRequest.setRequestHeader('Content-Type', mimeType);

xmlHttpRequest.setRequestHeader('Content-Disposition', 'attachment; filename="' + fileName + '"');

xmlHttpRequest.send(file);

Content-Type和Content-Disposition标头用于解释我们要发送的内容(MIME类型和文件名)。


我也在这里发布了类似的答案。


查看完整回答
反对 回复 2019-11-12
?
aluckdog

TA贡献1847条经验 获得超7个赞

基于本教程,这里有一个非常基本的方法:


$('your_trigger_element_selector').on('click', function(){    

    var data = new FormData();

    data.append('input_file_name', $('your_file_input_selector').prop('files')[0]);

    // append other variables to data if you want: data.append('field_name_x', field_value_x);


    $.ajax({

        type: 'POST',               

        processData: false, // important

        contentType: false, // important

        data: data,

        url: your_ajax_path,

        dataType : 'json',  

        // in PHP you can call and process file in the same way as if it was submitted from a form:

        // $_FILES['input_file_name']

        success: function(jsonData){

            ...

        }

        ...

    }); 

});

不要忘记添加适当的错误处理


查看完整回答
反对 回复 2019-11-12
  • 3 回答
  • 0 关注
  • 499 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信