>웹 프론트엔드 >HTML 튜토리얼 >HTML에서 비동기적으로 파일을 업로드하는 방법

HTML에서 비동기적으로 파일을 업로드하는 방법

php中世界最好的语言
php中世界最好的语言원래의
2018-02-08 09:38:092284검색

이번에는 HTML에서 파일을 비동기적으로 업로드하는 방법과 HTML에서 파일을 비동기적으로 업로드할 때 주의해야 할 주의사항에 대해 설명하겠습니다. 다음은 실제 사례입니다.

코드는 다음과 같습니다.

<form action="/hehe" method="post"> 
<input type="text" value="hehe"/> 
<input type="submit" value="upload" id="upload"/> 
</form>

이것은 HTML에서 가장 일반적이고 간단한 양식 제출 방법이지만 이 방법은 페이지를 전환해야 할 수도 있습니다. 때로는 동일한 페이지에서 서버와 상호 작용하고 싶지만 완료하고 싶지 않을 수도 있습니다. 양식을 작성한 후 다른 페이지로 전환하면 어떻게 해야 합니까? 양식을 제출하는 방법에는 여러 가지가 있습니다.
먼저 곡선을 통해 국가를 구하는 솔루션을 소개합니다. 위의 코드 조각은 변경할 필요가 없습니다. 다음 코드

<iframe id="uploadFrame" name="uploadFrame"></iframe>

를 추가하고 target=uploadFrame 형식에 target 속성을 추가하면 됩니다. iframe의 id 값(또는 name 속성의 값, 시도해 본 후에 알 수 있음)과 일치해야 합니다.

간단히 설명하자면, 사실 여기 양식이 제출 후 새로 고쳐졌는데 왜 페이지로 이동이 안 되나요? 사실 iframe에서 새로 고쳤는데 iframe이 비어 있기 때문이죠. 즉, 비동기적인 느낌을 줍니다. 이것은 정통적인 방법은 아니지만, 물론, 이 방법은 많은 경우에 적용되지 않습니다. 우리는 완성된 양식을 제출한 후 서버에서 가져오기를 원합니다. 이 방법은 분명히 작동하지 않습니다. 여기서는 진정한 비동기 제출 양식도 필요합니다.

(2)jquery양식의 비동기 제출

여기에서는 jquery용 양식 제출 플러그인인 ajaxupload를 소개합니다. 사용하기도 비교적 간단합니다.

<body> 
<form action="/hehe" method="post"> 
<input type="text" value="hehe"/> 
<input type="button" value="upload" id="upload"/> 
<!--<input type="button" value="send" onclick="send()"/>--> 
</form> 
<script> 
(function(){ 
new AjaxUpload("#upload", { 
action: &#39;/hehe&#39;, 
type:"post", 
data: {}, 
name: &#39;textfield&#39;, 
onSubmit: function(file, ext) { 
alert("上传成功"); 
}, 
onComplete: function(file, response) { 
} 
}); 
})(); 
</script> 
</body>


기본 코드는 여기에 게시되며, 페이지는 다음과 같습니다. 렌더링이 완료되면 자체 실행 함수를 사용하여 업로드 ID가 있는 버튼에 비동기 업로드 이벤트를 추가합니다. new AjaxUpload(id, object)의 id는 바인딩된 객체의 ID에 해당합니다. 두 번째 매개변수에는 데이터가 추가됩니다. onSubmit 함수는 파일을 업로드하기 전의 콜백 함수이며, ext는 파일 접미사입니다. 함수를 사용하면 서버에서 반환된 데이터를 처리할 수 있습니다. 위는 두 개의 간단한 파일 업로드 클라이언트를 구현한 것입니다. 이 사례를 읽으신 후 방법을 마스터하셨다고 생각합니다. 더 흥미로운 정보를 보려면 PHP 중국어 웹사이트의 다른 관련 기사를 주목하세요!

관련 읽기:

IE 웹 페이지 팝업 창의 매개변수는 무엇입니까?


Div


의 테두리 및 투명도 스타일을 설정하는 방법 div 태그

위 내용은 HTML에서 비동기적으로 파일을 업로드하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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