>웹 프론트엔드 >H5 튜토리얼 >HTML5 FormData 사용법에 대한 자세한 설명 및 파일 업로드 구현 프로세스에 대한 설명

HTML5 FormData 사용법에 대한 자세한 설명 및 파일 업로드 구현 프로세스에 대한 설명

巴扎黑
巴扎黑원래의
2017-09-13 10:10:275127검색

이 글에서는 주로 HTML5 FormData 메소드의 소개와 파일 업로드 예제의 구현을 소개합니다. 관심 있는 분들은 이에 대해 알아볼 수 있습니다.

XMLHttpRequest는 Javascript가 HTTP( 스) 의사소통. XMLHttpRequest는 최신 브라우저에서 앞뒤 간에 데이터를 상호 작용하는 데 일반적으로 사용되는 방법입니다. 2008년 2월에 XMLHttpRequest 레벨 2 초안이 제안되었으며, 그 중 몇 가지 새로운 기능이 있습니다. 그 중 FormData는 양식을 제출하고 양식 제출을 시뮬레이션하는 데 사용됩니다. 가장 큰 장점은 바이너리 파일을 업로드할 수 있다는 점입니다. FormData를 사용하여 파일을 업로드하는 방법에 대한 자세한 소개는 다음과 같습니다.

FormData 업로드 파일 예

먼저 formData의 기본 사용법을 살펴보겠습니다. FormData 개체는 모든 양식 요소의 이름과 값을 queryString으로 결합하여 백그라운드에 제출할 수 있습니다. 양식 양식을 FormData 생성자에 매개변수로 전달하기만 하면 됩니다.


var form = document.getElementById("form1");
var fd = new FormData(form);

이 방법으로 ajax의 send() 메소드를 통해 fd를 백그라운드로 직접 보낼 수 있습니다.

다음은 양식을 생성하는 것 외에도 양식에 파일 업로드도 있습니다. 양식 객체를 FormData 객체에 매개변수로 직접 전달합니다.


<form name="form1" id="form1">  
        <p>name:<input type="text" name="name" /></p>  
        <p>gender:<input type="radio" name="gender" value="1" />male <input type="radio" name="gender" value="2" />female</p>
        <p>stu-number:<input type="text" name="number" /></p>  
        <p>photo:<input type="file" name="photo" id="photo"></p>  
        <p><input type="button" name="b1" value="submit" onclick="fsubmit()" /></p>  
</form>  
<p id="result"></p>

위 코드는 양식을 생성하고 단순히 정보를 입력하고 사진을 아바타로 선택한 다음 반환된 결과를 저장할 p를 설정합니다.

HTML5 FormData 사용법에 대한 자세한 설명 및 파일 업로드 구현 프로세스에 대한 설명

단순함을 위해 jquery로 캡슐화된 ajax를 사용하여 데이터를 백그라운드로 전송합니다.


function fsubmit() {
        var form=document.getElementById("form1");
        var fd =new FormData(form);
        $.ajax({
             url: "server.php",
             type: "POST",
             data: fd,
             processData: false,  // 告诉jQuery不要去处理发送的数据
             contentType: false,   // 告诉jQuery不要去设置Content-Type请求头
             success: function(response,status,xhr){
                console.log(xhr);
                var json=$.parseJSON(response);
                var result = &#39;&#39;;
                result +="个人信息:<br/>name:"+json[&#39;name&#39;]+"<br/>gender:"+json[&#39;gender&#39;]+"<br/>number:"+json[&#39;number&#39;];
                 result += &#39;<br/>头像:<img  src="&#39; + json[&#39;photo&#39;] + &#39;"    style="max-width:90%" style="border-radius: 50%;" / alt="HTML5 FormData 사용법에 대한 자세한 설명 및 파일 업로드 구현 프로세스에 대한 설명" >&#39;;
                 $(&#39;#result&#39;).html(result);
             }
        });
        return false;
    }

위 코드의 server.php는 ajax 요청을 받고 수신된 내용을 반환하는 서버측 파일입니다. 구체적으로 코드는 다음과 같습니다.


<?php

$name = isset($_POST[&#39;name&#39;])? $_POST[&#39;name&#39;] : &#39;&#39;;  
$gender = isset($_POST[&#39;gender&#39;])? $_POST[&#39;gender&#39;] : &#39;&#39;;
$number = isset($_POST[&#39;number&#39;])? $_POST[&#39;number&#39;] : &#39;&#39;;  
$filename = time().substr($_FILES[&#39;photo&#39;][&#39;name&#39;], strrpos($_FILES[&#39;photo&#39;][&#39;name&#39;],&#39;.&#39;));  
$response = array();

if(move_uploaded_file($_FILES[&#39;photo&#39;][&#39;tmp_name&#39;], $filename)){  
    $response[&#39;isSuccess&#39;] = true;  
    $response[&#39;name&#39;] = $name;  
    $response[&#39;gender&#39;] = $gender;
    $response[&#39;number&#39;] = $number;  
    $response[&#39;photo&#39;] = $filename;  
}else{  
    $response[&#39;isSuccess&#39;] = false;  
}  
echo json_encode($response);

?>

정보를 입력한 후 제출을 클릭하면 페이지에서 다음과 같은 효과를 얻을 수 있습니다. 업로드된 사진은 서버 측의 해당 폴더에서도 확인할 수 있습니다.

HTML5 FormData 사용법에 대한 자세한 설명 및 파일 업로드 구현 프로세스에 대한 설명

기본 JavaScript 애호가라면 물론 위의 기능도 달성할 수 있습니다. 다음은 간단한 JavaScript 구현 코드입니다.


function fsubmit() {
    var form=document.getElementById("form1");
    var formData=new FormData(form);
    alert(formData.name);
    var oReq = new XMLHttpRequest();
    oReq.onreadystatechange=function(){
      if(oReq.readyState==4){
        if(oReq.status==200){
            console.log(typeof oReq.responseText);
            var json=JSON.parse(oReq.responseText);
            var result = &#39;&#39;;
            result +="个人信息:<br/>name:"+json[&#39;name&#39;]+"<br/>gender:"+json[&#39;gender&#39;]+"<br/>number:"+json[&#39;number&#39;];
             result += &#39;<br/>头像:<img  src="&#39; + json[&#39;photo&#39;] + &#39;"    style="max-width:90%" style="border-radius: 50%;" / alt="HTML5 FormData 사용법에 대한 자세한 설명 및 파일 업로드 구현 프로세스에 대한 설명" >&#39;;

             $(&#39;#result&#39;).html(result);
        }
      }
    };
    oReq.open("POST", "server.php");
    oReq.send(formData); 
    return false;
}

FormData 객체 메서드 소개

FormData 위의 내용은 새 객체를 생성할 때 양식을 매개변수로 직접 전달하는 것 외에도 다른 기능이 있습니다. 인터넷에 있는 FormData에 관한 대부분의 기사에는 Append() 메서드만 언급되어 있는데, FormData 개체에는 어떤 메서드가 있습니까? 우리는 콘솔에서 즉시 알게 될 것입니다:

HTML5 FormData 사용법에 대한 자세한 설명 및 파일 업로드 구현 프로세스에 대한 설명

콘솔 후에 우리는 중요한 발견을 했고, FormData 객체는 실제로 그러한 메소드를 가지고 있으므로, 진실을 알아내기 위해 우리는 여전히 그것을 스스로 테스트해야 합니다. 아래에서 이러한 메소드를 하나씩 설명하겠습니다. :

1.append()

append() 메소드는 FormData 객체에 키-값 쌍을 추가하는 데 사용됩니다.


fd.append(&#39;key1&#39;,"value1");
fd.append(&#39;key2&#39;,"value2");

fd는 새로 생성된 빈 객체일 수 있는 FormData 객체입니다. 또는 양식이나 다른 키-값 쌍이 이미 포함되어 있을 수도 있습니다.

2.set()

해당 키 키와 해당 값 값을 설정합니다


fd.set(&#39;key1&#39;,"value1");
fd.set(&#39;key2&#39;,"value2");

append() 메소드와 약간 비슷해 보입니다. 지정된 키 값이 존재하는 경우, 추가() 메소드는 새로 추가된 모든 키-값 쌍을 끝에 추가하고, set() 메소드는 이전에 설정된 키-값 쌍을 덮어씁니다. 여전히 예제를 비교하면서 이전 형식을 기반으로 새 키-값 쌍을 추가() 또는 설정()합니다.


fd.append(&#39;name&#39;,"will");

키 이름이 있는 두 개의 키-값 쌍이 있습니다:

HTML5 FormData 사용법에 대한 자세한 설명 및 파일 업로드 구현 프로세스에 대한 설명


fd.set(&#39;name&#39;,"will");

키 이름이 있는 키-값 쌍은 하나만 있습니다:

HTML5 FormData 사용법에 대한 자세한 설명 및 파일 업로드 구현 프로세스에 대한 설명

위는 append()와 set()의 차이점입니다. 설정된 키 값이 존재하지 않는 경우 둘의 효과는 동일합니다.

3.delete()

는 삭제하려는 키 값의 이름을 나타내는 매개변수를 받습니다. 동일한 키 값이 여러 개 있으면 함께 삭제됩니다.


fd.append(&#39;name&#39;,&#39;will&#39;);
fd.delete(&#39;name&#39;);

이름 정보 Append()를 통해 추가된 이름의 정보는 삭제됩니다.

4. get() 및 getAll()

찾아야 하는 키의 이름을 나타내는 매개변수를 받고 해당 키에 해당하는 첫 번째 값을 반환합니다. 동일한 키가 여러 개인 경우 해당 키에 해당하는 모든 값을 반환해야 합니다.

위의 양식 양식과 유사하게:


fd.append(&#39;name&#39;,&#39;will&#39;);
console.log(fd.get(&#39;name&#39;)); // sean


fd.append(&#39;name&#39;,&#39;will&#39;);
console.log(fd.getAll(&#39;name&#39;)); // ["sean", "will"]

5, has()

该方法也接收一个参数,同样是 key 的名称,返回一个Boolean 值, 用来判断FormData 对象是否含有该 key。以上面的form为例:


console.log(fd.has(&#39;name&#39;)); // true
console.log(fd.has(&#39;Name&#39;)); // false

6、keys()

该方法不需要接收参数,返回一个迭代器,通过这个迭代器,我们可以遍历FormData 对象中所有的 key。以上面的form为例:


for (var key of fd.keys()) {
           console.log(key); 
        }

结果为:

name
gender
number
photo

7、values()

有遍历 key 的迭代,当然也就少不了遍历 value 的迭代器了。values()就是遍历value 的迭代器,用法与 keys() 类似:


for (var value of fd.values()) {
           console.log(value); 
        }

结果:

HTML5 FormData 사용법에 대한 자세한 설명 및 파일 업로드 구현 프로세스에 대한 설명

8、entries()

有遍历 key 的迭代器,也有遍历 value 的迭代器,为何不搞一个两者一起的呢!entries()就是返回一个包含键值对的迭代器:


for(var pair of fd.entries()) {
           console.log(pair[0]+ &#39;, &#39;+ pair[1]); 
        }

结果:

HTML5 FormData 사용법에 대한 자세한 설명 및 파일 업로드 구현 프로세스에 대한 설명

FormData兼容性问题

由于 FormData 是 XMLHttpRequest Level 2 新增的接口,现在 低于IE10 的IE浏览器不支持 FormData ,至于 上面介绍的 FormData 对象的方法经过测试,在 IE 浏览器中都不支持,具体的各大浏览器的支持情况可以参照下图:

HTML5 FormData 사용법에 대한 자세한 설명 및 파일 업로드 구현 프로세스에 대한 설명

위 내용은 HTML5 FormData 사용법에 대한 자세한 설명 및 파일 업로드 구현 프로세스에 대한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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