이 글에서는 주로 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를 설정합니다.
단순함을 위해 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 = ''; result +="个人信息:<br/>name:"+json['name']+"<br/>gender:"+json['gender']+"<br/>number:"+json['number']; result += '<br/>头像:<img src="/static/imghwm/default1.png" data-src="' + json['photo'] + '" class="lazy" style="max-width:90%" style="border-radius: 50%;" / alt="HTML5 FormData 사용법에 대한 자세한 설명 및 파일 업로드 구현 프로세스에 대한 설명" >'; $('#result').html(result); } }); return false; }
위 코드의 server.php는 ajax 요청을 받고 수신된 내용을 반환하는 서버측 파일입니다. 구체적으로 코드는 다음과 같습니다.
<?php $name = isset($_POST['name'])? $_POST['name'] : ''; $gender = isset($_POST['gender'])? $_POST['gender'] : ''; $number = isset($_POST['number'])? $_POST['number'] : ''; $filename = time().substr($_FILES['photo']['name'], strrpos($_FILES['photo']['name'],'.')); $response = array(); if(move_uploaded_file($_FILES['photo']['tmp_name'], $filename)){ $response['isSuccess'] = true; $response['name'] = $name; $response['gender'] = $gender; $response['number'] = $number; $response['photo'] = $filename; }else{ $response['isSuccess'] = false; } echo json_encode($response); ?>
정보를 입력한 후 제출을 클릭하면 페이지에서 다음과 같은 효과를 얻을 수 있습니다. 업로드된 사진은 서버 측의 해당 폴더에서도 확인할 수 있습니다.
기본 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 = ''; result +="个人信息:<br/>name:"+json['name']+"<br/>gender:"+json['gender']+"<br/>number:"+json['number']; result += '<br/>头像:<img src="/static/imghwm/default1.png" data-src="' + json['photo'] + '" class="lazy" style="max-width:90%" style="border-radius: 50%;" / alt="HTML5 FormData 사용법에 대한 자세한 설명 및 파일 업로드 구현 프로세스에 대한 설명" >'; $('#result').html(result); } } }; oReq.open("POST", "server.php"); oReq.send(formData); return false; }
FormData 객체 메서드 소개
FormData 위의 내용은 새 객체를 생성할 때 양식을 매개변수로 직접 전달하는 것 외에도 다른 기능이 있습니다. 인터넷에 있는 FormData에 관한 대부분의 기사에는 Append() 메서드만 언급되어 있는데, FormData 개체에는 어떤 메서드가 있습니까? 우리는 콘솔에서 즉시 알게 될 것입니다:
콘솔 후에 우리는 중요한 발견을 했고, FormData 객체는 실제로 그러한 메소드를 가지고 있으므로, 진실을 알아내기 위해 우리는 여전히 그것을 스스로 테스트해야 합니다. 아래에서 이러한 메소드를 하나씩 설명하겠습니다. :
1.append()
append() 메소드는 FormData 객체에 키-값 쌍을 추가하는 데 사용됩니다.
fd.append('key1',"value1"); fd.append('key2',"value2");
fd는 새로 생성된 빈 객체일 수 있는 FormData 객체입니다. 또는 양식이나 다른 키-값 쌍이 이미 포함되어 있을 수도 있습니다.
2.set()
해당 키 키와 해당 값 값을 설정합니다
fd.set('key1',"value1"); fd.set('key2',"value2");
append() 메소드와 약간 비슷해 보입니다. 지정된 키 값이 존재하는 경우, 추가() 메소드는 새로 추가된 모든 키-값 쌍을 끝에 추가하고, set() 메소드는 이전에 설정된 키-값 쌍을 덮어씁니다. 여전히 예제를 비교하면서 이전 형식을 기반으로 새 키-값 쌍을 추가() 또는 설정()합니다.
fd.append('name',"will");
키 이름이 있는 두 개의 키-값 쌍이 있습니다:
fd.set('name',"will");
키 이름이 있는 키-값 쌍은 하나만 있습니다:
위는 append()와 set()의 차이점입니다. 설정된 키 값이 존재하지 않는 경우 둘의 효과는 동일합니다.
3.delete()
는 삭제하려는 키 값의 이름을 나타내는 매개변수를 받습니다. 동일한 키 값이 여러 개 있으면 함께 삭제됩니다.
fd.append('name','will'); fd.delete('name');
이름 정보 Append()를 통해 추가된 이름의 정보는 삭제됩니다.
4. get() 및 getAll()
찾아야 하는 키의 이름을 나타내는 매개변수를 받고 해당 키에 해당하는 첫 번째 값을 반환합니다. 동일한 키가 여러 개인 경우 해당 키에 해당하는 모든 값을 반환해야 합니다.
위의 양식 양식과 유사하게:
fd.append('name','will'); console.log(fd.get('name')); // sean
fd.append('name','will'); console.log(fd.getAll('name')); // ["sean", "will"]
5, has()
该方法也接收一个参数,同样是 key 的名称,返回一个Boolean 值, 用来判断FormData 对象是否含有该 key。以上面的form为例:
console.log(fd.has('name')); // true console.log(fd.has('Name')); // 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); }
结果:
8、entries()
有遍历 key 的迭代器,也有遍历 value 的迭代器,为何不搞一个两者一起的呢!entries()就是返回一个包含键值对的迭代器:
for(var pair of fd.entries()) { console.log(pair[0]+ ', '+ pair[1]); }
结果:
FormData兼容性问题
由于 FormData 是 XMLHttpRequest Level 2 新增的接口,现在 低于IE10 的IE浏览器不支持 FormData ,至于 上面介绍的 FormData 对象的方法经过测试,在 IE 浏览器中都不支持,具体的各大浏览器的支持情况可以参照下图:
위 내용은 HTML5 FormData 사용법에 대한 자세한 설명 및 파일 업로드 구현 프로세스에 대한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

H5는 멀티미디어 지원, 오프라인 스토리지 및 성능 최적화로 웹 사용자 경험을 향상시킵니다. 1) 멀티미디어 지원 : H5 및 요소는 개발을 단순화하고 사용자 경험을 향상시킵니다. 2) 오프라인 스토리지 : WebStorage 및 IndexedDB는 오프라인으로 사용하여 경험을 향상시킵니다. 3) 성능 최적화 : 웹 워즈 및 요소는 성능을 최적화하여 대역폭 소비를 줄입니다.

HTML5 코드는 태그, 요소 및 속성으로 구성됩니다. 1. 태그는 컨텐츠 유형을 정의하고 다음과 같은 각도 브래킷으로 둘러싸여 있습니다. 2. 요소는 컨텐츠와 같은 시작 태그, 내용 및 엔드 태그로 구성됩니다. 3. 속성 시작 태그에서 키 값 쌍을 정의하고 기능을 향상시킵니다. 웹 구조를 구축하기위한 기본 단위입니다.

HTML5는 현대적인 웹 페이지를 구축하는 핵심 기술로 많은 새로운 요소와 기능을 제공합니다. 1. HTML5는 웹 페이지 구조 및 SEO를 향상시키는 의미 론적 요소를 소개합니다. 2. 멀티미디어 요소를 지원하고 플러그인없이 미디어를 포함시킵니다. 3. 양식은 새로운 입력 유형 및 검증 속성을 향상시켜 검증 프로세스를 단순화합니다. 4. 웹 페이지 성능 및 사용자 경험을 향상시키기 위해 오프라인 및 로컬 스토리지 기능을 제공합니다.

H5 코드에 대한 모범 사례는 다음과 같습니다. 1. 올바른 문서 선언 및 문자 인코딩 사용; 2. 시맨틱 태그를 사용하십시오. 3. HTTP 요청을 줄입니다. 4. 비동기 부하 사용; 5. 이미지 최적화. 이러한 관행은 웹 페이지의 효율성, 유지 관리 및 사용자 경험을 향상시킬 수 있습니다.

웹 표준과 기술은 현재까지 HTML4, CSS2 및 간단한 JavaScript에서 발전했으며 중대한 개발을 거쳤습니다. 1) HTML5는 캔버스 및 웹 스토리지와 같은 API를 도입하여 웹 응용 프로그램의 복잡성과 상호 작용을 향상시킵니다. 2) CSS3은 애니메이션 및 전환 기능을 추가하여 페이지를보다 효과적으로 만듭니다. 3) JavaScript는 화살표 기능 및 클래스와 같은 Node.js 및 ES6의 최신 구문을 통해 개발 효율 및 코드 가독성을 향상시킵니다. 이러한 변경으로 인해 웹 애플리케이션의 성능 최적화 및 모범 사례의 개발이 촉진되었습니다.

H5는 HTML5의 약어 일뿐 만 아니라 더 넓은 현대 웹 개발 기술 생태계를 나타냅니다. 1. H5는 HTML5, CSS3, JavaScript 및 관련 API 및 기술을 포함합니다. 2. 그것은 더 풍부하고 대화식이며 부드러운 사용자 경험을 제공하며 여러 장치에서 원활하게 실행할 수 있습니다. 3. H5 기술 스택을 사용하여 반응 형 웹 페이지와 복잡한 대화식 기능을 만들 수 있습니다.

H5 및 HTML5는 동일한 것을, 즉 html5를 나타냅니다. HTML5는 HTML의 다섯 번째 버전으로 시맨틱 태그, 멀티미디어 지원, 캔버스 및 그래픽, 오프라인 스토리지 및 로컬 스토리지와 같은 새로운 기능을 제공하여 웹 페이지의 표현성 및 상호 작용성을 향상시킵니다.

h5referstohtml5, apivotaltechnologyinwebdevelopment.1) html5introducesnewelements 및 dynamicwebapplications.2) itsupp ortsmultimediawithoutplugins, enovannangeserexperienceacrossdevices.3) SemanticLementsImproveContentsTructUreAndSeo.4) H5'Srespo


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

Dreamweaver Mac版
시각적 웹 개발 도구

WebStorm Mac 버전
유용한 JavaScript 개발 도구

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경
