/**
* @param url
* @param param 参数对象(包含文件):param.file(el-upload)/param.target.files[0](input[file])
* @param cb 发送成功的回调函数
*/
export function requestImport(url, param, cb, queryStr) {
var file
// 加上param.raw,有的组件取回的文件对象,属性值放在raw而非file里
if (param.file || param.raw) {
file = param.file || param.raw
} else {
file = param.target.files[0]
}
var fullUrl = url + `?token=${Cookies.get('token')}`
// 设置全路径
if (fullUrl.indexOf('http://') !== 0 && fullUrl.indexOf('https://') !== 0) {
fullUrl = process.env.VUE_APP_BASE_API + fullUrl
}
var xhr = new XMLHttpRequest()
xhr.open('POST', fullUrl + (queryStr || ''))
xhr.setRequestHeader('Authorization', Cookies.get('token'))
xhr.overrideMimeType('application/octet-stream')
var chunks = file.slice(0, file.size)
this.$utils.getFileBinary(chunks, function (binary) {
if (xhr.sendAsBinary) {
xhr.sendAsBinary(binary)
} else {
xhr.send(binary)
}
})
xhr.onreadystatechange = function (e) {
if (xhr.readyState === 4) {
if (xhr.status === 200) {
var resp = JSON.parse(xhr.responseText)
if (typeof cb === 'function') {
cb.call(this, resp)
}
}
}
}
}
原生Ajax发送文件流
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
推荐阅读更多精彩内容
- 1.html 2.修改axios请求的responseType为blob,以post请求为例 3.进行请求处理
- (1)Ajax(就是XHR(XMLHttpRequest)),是异步的JavaScript和XML,是一种用于创建...
- http.request 发送服务请求 http.request返回一个可写流http.ClientRequest...