본 글에서는 자바스크립트를 이용하여 구현한 매우 실용적인 기능에 대해 설명하겠습니다. 첨부파일 업로드 시 파일 선택 상자를 동적으로 추가 및 삭제한 후 한꺼번에 업로드할 수 있습니다.
이론적으로는 구현하기가 비교적 쉽지만 실제 작업에서는 여전히 두 가지 어려움에 직면합니다. 이러한 어려움은 모두 브라우저 호환성 때문입니다. 스크립트에는 insertAdjacentHTML, RemoveChild 두 가지 함수가 사용되는데, Firefox에서는 이 두 함수를 정상적으로 사용할 수 없는 경우가 있습니다. 거의 하루 종일 인터넷으로 해결책을 찾아 헤매다가 다행히 발견되어 안도의 한숨을 쉬었습니다.
구체적인 두 가지 기능은 다음과 같습니다.
<script type="text/javascript"> //删除文件选择框 function removeFile(id) { var new_tr = id.parentNode; try { //new_tr.removeNode(true); // just ie , not w3c; // other idea var tmp = new_tr.parentNode; // 为了在ie和firefox下都能正常使用,就要用另一个方法代替,最取上一层的父结点,然后remove. tmp.removeChild(new_tr); } catch(e) {} } //添加文件选择框 function addFile(id) { var str = '<div><input type="file" runat="server" name="file" onKeyDown="this.blur();" oncontextmenu="return false" /><input type="button" value="删除" style="height:22px;" onclick="removeFile(this)" /></div>' insertHtml("beforeend",document.getElementById(id),str); } </script>
페이지에 인용되어 있습니다.
<div> <input type="button" value="添加附件(Add)" onclick="addFile('myfile')"> </div> <div id="myfile"> </div>
은 addFile 함수의 또 다른 함수인 insertHtml을 참조합니다. 이 함수는 주로 Firefox에서 insertAdjacentHTML이 유효하지 않은 경우를 위해 다시 작성되었습니다. insertAdjacentHTML을 검색하면 찾을 수 있습니다.
PS: 파일함 내용 지우기
<input type=file name=ttt> <input type=button onclick="ttt.select();document.execCommand('Delete');" value=清除file框的内容>
두 번째 경우
파일 업로드, 삭제 렌더링 :
방금 시작함:
"추가 선택 후" 버튼을 클릭하면 많은 선택 파일을 추가할 수 있습니다:
'삭제' 버튼 클릭 후:
구현 코드:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>选择文件</title> <style type="text/css"> *{ margin:0px; padding:0px; } div{ margin:10px; } </style> <script> //当点击添加更多时,增加一个DIV //先增加两个input function addFile(){ var fragment=document.createDocumentFragment(); var divNode=document.getElementById("container"); var newDiv=document.createElement("div"); newDiv.setAttribute("id","file"); fragment.appendChild(newDiv); var newInput=document.createElement("input"); newInput.setAttribute("type","file"); newInput.setAttribute("name","选择文件"); newDiv.appendChild(newInput); var newInput=document.createElement("input"); newInput.setAttribute("type","button"); newInput.setAttribute("value","删除"); newInput.setAttribute("onclick","delFile()"); newInput.setAttribute("id","1"); newDiv.appendChild(newInput); divNode.appendChild(fragment); } function delFile(){ var divNode=document.getElementById("container"); divNode.removeChild(divNode.firstElementChild); } </script> </head> <body> <input type="button" value="选择更多" onclick="addFile()"/> <div id="container"> <div id="file"> <input type="file" name="选择文件"/> <input type="button" value="删除" onclick="delFile()" /> </div> </div> </body> </html>