js はファイルのアップロード、ファイル選択ボックスの追加と削除を実装します。

高洛峰
リリース: 2016-12-09 11:51:23
オリジナル
1687 人が閲覧しました

この記事では、添付ファイルをアップロードするときに、ファイル選択ボックスを動的に追加および削除し、それらを一度にアップロードできる非常に実用的な機能について説明します。

理論的には実装は比較的簡単ですが、実際の作業では依然として 2 つの困難に直面します。これらの困難はすべて 1 つの理由に起因しており、それはブラウザーの互換性です。スクリプト内ではinsertAdjacentHTMLとremoveChildの2つの関数が使用されていますが、Firefoxではこれら2つの関数が正常に使用できない場合があります。ほぼ 1 日かけてインターネットで解決策を探しましたが、幸運にも見つかり、安堵のため息をつきました。

具体的な 2 つの関数は次のとおりです:

<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。この関数は主に以下の insertAdjacentHTML 用です。 firefox 無効な場合は書き換えられます。 insertAdjacentHTML で検索すると見つかります。

追記: ファイルボックスの内容をクリアします

<input  type=file  name=ttt>   
 <input  type=button  onclick="ttt.select();document.execCommand(&#39;Delete&#39;);"   value=清除file框的内容>
ログイン後にコピー

2番目のケース

ファイルのアップロード、レンダリングの削除:

開始したばかりです:

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>
ログイン後にコピー


関連ラベル:
js
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!