>  기사  >  웹 프론트엔드  >  js는 파일 업로드, 파일 선택 상자 추가 및 삭제를 구현합니다.

js는 파일 업로드, 파일 선택 상자 추가 및 삭제를 구현합니다.

高洛峰
高洛峰원래의
2016-12-09 11:51:231688검색

본 글에서는 자바스크립트를 이용하여 구현한 매우 실용적인 기능에 대해 설명하겠습니다. 첨부파일 업로드 시 파일 선택 상자를 동적으로 추가 및 삭제한 후 한꺼번에 업로드할 수 있습니다.

이론적으로는 구현하기가 비교적 쉽지만 실제 작업에서는 여전히 두 가지 어려움에 직면합니다. 이러한 어려움은 모두 브라우저 호환성 때문입니다. 스크립트에는 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 = &#39;<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>&#39;
   insertHtml("beforeend",document.getElementById(id),str);
   }
</script>

페이지에 인용되어 있습니다.

<div>
    <input type="button" value="添加附件(Add)" onclick="addFile(&#39;myfile&#39;)">
    </div>
  <div id="myfile">
</div>

은 addFile 함수의 또 다른 함수인 insertHtml을 참조합니다. 이 함수는 주로 Firefox에서 insertAdjacentHTML이 유효하지 않은 경우를 위해 다시 작성되었습니다. insertAdjacentHTML을 검색하면 찾을 수 있습니다.

PS: 파일함 내용 지우기

<input  type=file  name=ttt>   
 <input  type=button  onclick="ttt.select();document.execCommand(&#39;Delete&#39;);"   value=清除file框的内容>

두 번째 경우

파일 업로드, 삭제 렌더링 :

방금 시작함:

js는 파일 업로드, 파일 선택 상자 추가 및 삭제를 구현합니다.

"추가 선택 후" 버튼을 클릭하면 많은 선택 파일을 추가할 수 있습니다:

js는 파일 업로드, 파일 선택 상자 추가 및 삭제를 구현합니다.

'삭제' 버튼 클릭 후:

js는 파일 업로드, 파일 선택 상자 추가 및 삭제를 구현합니다.

구현 코드:

<!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>


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