JS上传多种类型参数

以前用form表单提交参数遇到过只能传单一参数的情况,如果要上传file文件,将表单类型里要写enctype="multipart/form-data",但是一旦表单里还有一些普通参数的话,这个表单就只能提交文件,提交不了剩余普通参数。

当遇到这种复合表单提交的情况时,我的解决方案是:

利用FormData对象,可以使用一系列的键值对来模拟一个完整的表单,然后使用XMLHttpRequest发送这个"表单

代码如下:


function submit(){

     var xhr = new XMLHttpRequest();
            var fd = new FormData();
            fd.append('file', $('#file')[0].files[0]); //file类型参数
            fd.append('storeId', $scope.store.sId); //普通类型参数
            xhr.open('POST', '(提交路径)www.baidu.com');
            xhr.send(fd);
            xhr.addEventListener('load', uploadComplete, false);
            xhr.addEventListener('error', uploadFailed, false);
            xhr.addEventListener('abort', uploadCanceled, false);

}


//传输文件开始

        function uploadComplete(evt) {
            var data = JSON.parse(evt.target.responseText);
            alert(data.msg);
        }

        function uploadFailed(evt) {
            alert('There was an error attempting to upload the file.');
        }
        function uploadCanceled(evt) {
            alert('The upload has been canceled by the user or the browser dropped the connection.');
        }

//传输文件结束


后台(我们的框架是Spring MVC)控制器接口里的接收参数方式为:

@ApiParam(required = true, name = "storeId", value = "门店Id") @RequestParam Integer storeId,
@ApiParam(required = false, name = "file", value = "门店照片") @RequestParam MultipartFile file

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值