解决方案:js文件流、base64、Bolb、File、文件上传的使用

文件上传获取文件流

  1. 创建input 获取文件
    input file MDN文档
    <input type=file name=file> 
    
  2. 获取input 内的文件流
    返回值默认为集合(数组)
    document.querySelector("input[name=file]").files
    
    解决方案:js文件流、base64、Bolb、File、文件上传的使用_第1张图片

文件转换为Base64

function isBase64(str) {
    if (str === '' || str.trim() === '') { return false; }
    try {
        return btoa(atob(str)) == str
    } catch (err) {
        return false
    }
}

function getBase64(file) {
    return new Promise((resolve, reject) => {
        try {
            if (Object.prototype.toString.call(file) === "[object String]" && isBase64((file as any))) {
                resolve(file)
            } else {
                const reader = new FileReader()
                reader.readAsDataURL((file as any))
                reader.onload = () => resolve(reader.result)
                reader.onerror = (error) => reject(error)
            }
        } catch (err) { // 发生错误回调
            reject(err)
        }
    })
}

Base64 转换为二进制

function base64ToBlob(urlData, type) {
    let arr = urlData.split(',')
    let mime, bytes
    if (arr && arr.length === 2) {
        mime = (arr[0] as any).match(/:(.*?);/)[1] || type
        // 去掉url的头,并转化为byte
        bytes = window.atob(arr[1])
    } else {
        mime = type
        // 去掉url的头,并转化为byte
        bytes = window.atob(arr[0])
    }
    // 处理异常,将ascii码小于0的转换为大于0
    let ab = new ArrayBuffer(bytes.length)
    // 生成视图(直接针对内存):8位无符号整数,长度1个字节
    let ia = new Uint8Array(ab)
    for (let i = 0; i < bytes.length; i++) {
        ia[i] = bytes.charCodeAt(i)
    }
    return new Blob([ab], {
        type: mime
    })
}

二进制文件添加文件名

  • 文件上传时添加
    let formData = new FormData()
    formFata.append("file", base64ToBlob(base64), name) // file 为接口传递的字段,formData的属性值,name 为二进制文件的名称
    
  • 非文件上传时添加
    new File(base64ToBlob(base64), name) // name 为需设置的文件名称
    

文件上传至服务器

若使用第三方库,需修改 Content-Type 值为 multipart/form-data

function handleUpload () {
	let formData = new FormData()
	formData.append("file", document.querySelector("input[name=file]").files[0], "demo")
	xhr = new XMLHttpRequest()
	xhr.open("post", url,true)
	xhr.onload = uploadComplete //请求完成
	xhr.onerror =  uploadFailed //请求失败
	xhr.upload.onprogress = progressFunction
	xhr.send(formData)
}

function uploadComplete() {
	console.log("上传成功")
}

function uploadFailed() {
	console.log("上传失败")
}

function progressFunction(evt) {
	let loading = Math.round(evt.loaded / evt.total * 100);
	console.log(`已上传${loading}%`)
}

你可能感兴趣的:(JavaScript,javascript)