스택큐힙리스트

어떻게 jQuery를 사용하여 파일을 비동기적으로 업로드할 수 있을까요? 본문

카테고리 없음

어떻게 jQuery를 사용하여 파일을 비동기적으로 업로드할 수 있을까요?

스택큐힙리스트 2024. 1. 22. 14:38
반응형



$(document).ready(function () {

$(#uploadbutton).click(function () {
var filename = $(#file).val();

$.ajax({
type: POST,
url: addFile.do,
enctype: 'multipart/form-data',
data: {
file: filename
},
success: function () {
alert(Data Uploaded: );
}
});
});
});

<script src=https://cdnjs.cloudflare.com/ajax/libs/jquery/2.2.0/jquery.min.js></script>

<span>파일</span>
<input type=file id=file name=file size=10/>
<input id=uploadbutton type=button value=업로드/>


파일이 업로드되는 대신에, 파일 이름만 얻고 있습니다. 이 문제를 고치기 위해 어떻게 할 수 있을까요?

답변 1

$(':button').on('click', function () {
$.ajax({
// 업로드를 처리하는 서버 스크립트 URL
url: 'upload.php',
type: 'POST',

// 폼 데이터
data: new FormData($('form')[0]),

// 데이터 처리나 내용 유형에 대해 jQuery가 걱정하지 않도록 설정
// 반드시 다음 옵션들을 포함해야 합니다!
cache: false,
contentType: false,
processData: false,

// 사용자 정의 XMLHttpRequest
xhr: function () {
var myXhr = $.ajaxSettings.xhr();
if (myXhr.upload) {
// 업로드 진행률 처리를 위한 이벤트 핸들러
myXhr.upload.addEventListener('progress', function (e) {
if (e.lengthComputable) {
$('progress').attr({
value: e.loaded,
max: e.total,
});
}
}, false);
}
return myXhr;
}
});
});

보시다시피, HTML5를 사용하면 (그리고 일부 연구를 통해) 파일 업로드가 가능하고 매우 쉬워집니다. 일부 예제의 HTML5 구성 요소는 모든 브라우저에서 사용할 수 없으므로 Google Chrome으로 시도해보세요.

답변 2

jQuery를 사용하여 비동기적으로 파일을 업로드하는 방법에 대해 알아보겠습니다. 파일 업로드는 웹 애플리케이션에서 중요한 요소 중 하나입니다. 비동기 파일 업로드는 사용자 경험을 향상시키는 데 도움이 되며, 매우 유용한 도구인 jQuery를 사용하면 간편하게 구현할 수 있습니다.
1. jQuery Form 플러그인 사용하기:
jQuery Form 플러그인은 AJAX 파일 업로드를 간단하게 처리할 수 있는 훌륭한 도구입니다. 이 플러그인을 사용하면 폼 데이터를 비동기적으로 서버로 전송할 수 있습니다.
예를 들어, HTML 폼을 만들고 해당 폼을 전송할 때 아래 코드를 사용할 수 있습니다.
```javascript
$('#myForm').ajaxForm({
// 업로드 성공 시 실행될 콜백 함수
success: function(responseText, status, xhr, $form) {
// 업로드 성공 후 수행할 작업
},
// 업로드 진행 상황 표시를 위한 콜백 함수
uploadProgress: function(event, position, total, percentComplete) {
// 진행 상황 표시
}
});
```
위의 코드에서 `myForm`은 해당 폼의 ID입니다. `success` 콜백 함수는 서버로부터 응답을 받은 후 실행되고, `uploadProgress` 콜백 함수는 업로드 과정 중의 진행 상황을 표시하기 위해 사용됩니다.
2. XMLHttpRequest 객체 사용하기:
jQuery 없이 JavaScript의 XMLHttpRequest 객체를 사용하여 비동기 파일 업로드를 구현할 수도 있습니다. 이 방법은 더 많은 코드를 작성해야 하지만, 기본적인 아이디어는 비슷합니다.
```javascript
var formData = new FormData();
var file = $('#myFile')[0].files[0];
formData.append('file', file);
var xhr = new XMLHttpRequest();
xhr.open('POST', 'upload.php', true);
xhr.onload = function() {
if (xhr.status === 200) {
// 업로드 성공 시 수행될 작업
} else {
// 업로드 실패 시 수행될 작업
}
};
xhr.upload.onprogress = function(event) {
if (event.lengthComputable) {
var percentComplete = (event.loaded / event.total) * 100;
// 진행 상황 표시
}
};
xhr.send(formData);
```
위의 코드에서 `myFile`은 파일 입력 필드의 ID, `upload.php`는 파일을 서버에 전송할 PHP 스크립트의 경로입니다.
이와 같은 방법으로 jQuery를 사용하여 파일을 비동기적으로 업로드할 수 있습니다. 비동기 업로드는 웹 애플리케이션의 성능과 사용자 경험을 향상시키는 데 도움이 됩니다.

반응형
Comments