>웹 프론트엔드 >JS 튜토리얼 >JavaScript로 파일을 업로드하고 진행 상황을 추적하는 방법은 무엇입니까?

JavaScript로 파일을 업로드하고 진행 상황을 추적하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-10 04:38:021002검색

How to Upload Files with JavaScript and Track Their Progress?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.