JavaScript로 파일 업로드
입력 요소를 통해 선택한 파일을 업로드하려면 FormData 개체를 사용할 수 있습니다. 방법은 다음과 같습니다.
1. FormData 객체 생성:
let formData = new FormData();
2. FormData에 파일을 추가합니다.
let photo = document.getElementById("image-file").files[0]; formData.append("photo", photo);
3. 서버로 데이터 보내기:
가져오기 API를 사용하여 FormData를 지정된 URL로 보낼 수 있습니다:
fetch('/upload/image', {method: "POST", body: formData});
업로드 진행률 수신
업로드 진행 상황을 모니터링하려면 EventTarget의 addEventListener() 메서드를 사용할 수 있습니다.
let progressBar = document.getElementById("progress-bar"); formData.addEventListener("progress", (event) => { if (event.lengthComputable) { let percentComplete = Math.round((event.loaded / event.total) * 100); progressBar.style.width = percentComplete + "%"; } });
전체 코드 예
파일 업로드 결합 진행률을 단일 예로 추적합니다.
let formData = new FormData(); let photo = document.getElementById("image-file").files[0]; formData.append("photo", photo); let progressBar = document.getElementById("progress-bar"); fetch('/upload/image', {method: "POST", body: formData}) .then((response) => { console.log(response); // Handle server response }) .catch((error) => { console.error(error); // Handle upload failure }); formData.addEventListener("progress", (event) => { if (event.lengthComputable) { let percentComplete = Math.round((event.loaded / event.total) * 100); progressBar.style.width = percentComplete + "%"; } });
이 코드는 "/upload/image" URL에 대한 POST 요청을 생성하고 파일 데이터를 전송하며 진행률 표시줄을 사용하여 업로드 진행률을 표시합니다.
위 내용은 JavaScript로 파일을 업로드하고 진행 상황을 추적하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!