日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

原生JS实现文件上传

發布時間:2023/12/20 javascript 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 原生JS实现文件上传 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章導航

      • 1. 不使用 form 標簽
      • 2. 使用 form 標簽

1. 不使用 form 標簽

不使用 form 標簽,在提交的時候手動獲取 input[type='file'] 的 files 文件列表,手動處理數據:

let files = document.getElementById("input-upload").files //獲取文件列表 let formData =new FormData() formData.append("file", files[0])

2. 使用 form 標簽

使用 form 的時候一般不用 form 原生的 submit 提交方式,可以為 form 添加 onsubmit="return false" 來阻止默認的提交事件

使用form的優點
可以使用 new FormData(document.getElementById("formID")) 來獲取整個表單的數據

注意點:
使用 fetch() 的時候不應該單獨設置 headers:{"Content-Type":"multipart/form-data"}

<!DOCTYPE html> <html lang="zh"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title> </head> <style>html,body {font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";}button {outline: none;border: none;border-radius: 2px;border-top-right-radius: 5px;border-bottom-left-radius: 5px;}button:hover {cursor: pointer;box-shadow: 2px 2px 5px 0 rgba(0, 0, 0, 0.2);}#input-uploader {display: none;}.wrapper {border: 0.5px solid rgba(200, 200, 200, 0.1);padding: 20px;max-width: 1000px;text-align: center;margin: 100px auto;border-radius: 10px;}.primary-button {font-size: 1rem;color: #fefefe;background-color: rgb(117, 183, 245);border: none;border: 0.2px solid #7cd5f8;background-image: linear-gradient(45deg, rgba(117, 183, 245, 1), rgba(124, 213, 248, 1));/* border-radius: 5px; */outline: none;padding: 2px 10px;transition: all 0.2s ease;} </style><body><div class="wrapper"><form id="formData" onsubmit="return false;"><input type="file" webkitdirectory id="input-uploader" name="fileUpload"onchange="handleFileChange(this)" /><button class="primary-button button-upload" onclick="showUploader()">上傳文件夾</button></form></div> </body> <script>/*** 原生JS文件上傳* 1.不使用<form>* 不使用form標簽, 在提交的時候手動獲取 input[type='file'] 的 files 文件列表,* 進行手動處理數據:* files = document.getElementById("input-upload").files 獲取文件列表* let formData =new FormData()* formData.append("file", files[0])* * * 2.使用<form>* 使用form的時候一般不用form原生的提交方式,可以為form添加 οnsubmit="return false"來阻止默認的提交事件* ▲ 使用form的優點* 可以使用 new FormData(document.getElementById("formID"))來獲取整個表單的數據* * 注意點:* 使用fetch()的時候`不`應該單獨設置 headers:{"Content-Type":"multipart/form-data"}*//*** @description: 封裝fetch* @param {Object} FetchConfig fetch config* @return {Promise} fetch result*/const requestApi = ({url,method = 'GET',...fetchProps}) => {return fetch(url, {method,...fetchProps})//返回請求成功的結果.then(res => res && res.status === 200 && res.json()).catch(err => alert('未知錯誤')).then(res => res)}/*** @description: 打開文件選擇窗口(自定義上傳控件樣式,必須手動點擊原Input控件打開上傳窗口)* @param {*}* @return {*}*/const showUploader = () => {let uploaderInput = document.getElementById("input-uploader")uploaderInput.click()}/*** @description: 選擇文件后的處理* @param {*}* @return {*}*/handleFileChange = () => {let fileData = document.getElementById("input-uploader")const { files, value, form } = fileDatalet formData = new FormData();// Array.from() 將文件列表數據轉換為可遍歷數組Array.from(files).forEach(item => formData.append("uploadFile", item))console.log(formData)// 調用接口上傳文件handleUploadFile(formData).then(res => {if (res && res.success) {alert('上傳成功')//處理結果} else {alert(res?.message || '上傳失敗')}console.log(res)}).catch(err => alert('出錯'))}/*** @description: 文件上傳 - 請求接口(這里使用的是Mock接口,隨機返回success)* @param {FormData} formData* @return {*}*/const handleUploadFile = (formData = {}) =>requestApi({url: `http://rap2api.taobao.org/app/mock/data/2079322`,method: 'POST',body: formData});</script> </html>

總結

以上是生活随笔為你收集整理的原生JS实现文件上传的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。