欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js實(shí)現(xiàn)上傳文件添加和刪除文件選擇框

 更新時間:2016年10月24日 08:47:53   作者:烽火戲諸諸諸侯  
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)上傳文件添加和刪除文件選擇框 ,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文這里給大家說個用javascript實(shí)現(xiàn)的很實(shí)用的功能,是在上傳附件的時候,可以動態(tài)地添加和刪除文件選擇框,然后一次性上傳。

從理論上看,實(shí)現(xiàn)起來比較容易,但實(shí)際工作的時候還是遇到兩個難點(diǎn),這些難點(diǎn)歸結(jié)起來都是一個原因造成的,那就是瀏覽器的兼容性。在腳本中要用到兩個函數(shù):insertAdjacentHTML和removeChild,而恰好這兩個函數(shù)在Firefox下都不能正常使用。幾乎花費(fèi)了一天的時候,在網(wǎng)上搜索著解決的方法,還好被找到了,也讓我大松一口氣。

具體兩個函數(shù)是這樣的:

<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下都能正常使用,就要用另一個方法代替,最取上一層的父結(jié)點(diǎn),然后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函數(shù)中引用了另一個函數(shù):insertHtml,這個函數(shù)主要是針對insertAdjacentHTML在firefox下無效的情況重寫的,具體可以通過搜索insertAdjacentHTML找到。

PS:清除file框的內(nèi)容

<input  type=file  name=ttt>    
 <input  type=button  onclick="ttt.select();document.execCommand('Delete');"   value=清除file框的內(nèi)容>

第二個案例

文件上傳,刪除效果圖:

剛開始:

點(diǎn)擊按鈕“選擇更多后”,可以添加很多選擇文件:

點(diǎn)擊按鈕“刪除”后:

實(shí)現(xiàn)代碼:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>選擇文件</title>
<style type="text/css">
*{
margin:0px;
padding:0px;
}
div{
margin:10px;
}
</style>


<script>
//當(dāng)點(diǎn)擊添加更多時,增加一個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>

代碼瑕疵:!?。?!在刪除函數(shù)中,我選擇的是刪除第一個元素節(jié)點(diǎn),而不是真正意義上的刪除當(dāng)前按鈕,不知道怎么改善,求改正。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 原生JavaScript實(shí)現(xiàn)AJAX、JSONP

    原生JavaScript實(shí)現(xiàn)AJAX、JSONP

    本篇文章將會講解原生JavaScript如何實(shí)現(xiàn)簡單的AJAX,還有跨域請求JSONP。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-02-02
  • JavaScript中的迭代器和生成器詳解

    JavaScript中的迭代器和生成器詳解

    這篇文章主要介紹了JavaScript中的迭代器和生成器詳解,本文講解了迭代器、聲明自定義迭代器、生成器:一種更好的方式來構(gòu)建迭代器、生成器高級特性等內(nèi)容,需要的朋友可以參考下
    2014-10-10
  • ejs v9 javascript模板系統(tǒng)

    ejs v9 javascript模板系統(tǒng)

    我的模板系統(tǒng)升一下級, 繼續(xù)在新公司里面用。 現(xiàn)在幾在互聯(lián)網(wǎng)公司沒有不用javascript模板了, 什么TX, 百度, 新浪, 360什么的, 最后瀑布流的流行, 里面又有許多用到模板
    2012-03-03
  • canvas實(shí)現(xiàn)繪制吃豆魚效果

    canvas實(shí)現(xiàn)繪制吃豆魚效果

    本篇文章主要分享了canvas實(shí)現(xiàn)繪制吃豆魚效果的示例代碼,具有一定的參考價值,下面跟著小編一起來看下吧
    2017-01-01
  • 純JS實(shí)現(xiàn)輪播圖

    純JS實(shí)現(xiàn)輪播圖

    這幾天一直在看js動畫,今天又get到了一個輪播圖,使用純js實(shí)現(xiàn)的,但是外觀樣式不是很好看,如果大家有需要可以美化下,具體實(shí)現(xiàn)代碼還是很完整的,大家可以參考下
    2017-02-02
  • webpack-merge的使用教程

    webpack-merge的使用教程

    這篇文章主要介紹了webpack-merge的使用,webpack-merge 工具提供了各種 merge(合并) 高級功能,本文給大家詳細(xì)講解,需要的朋友可以參考下
    2023-02-02
  • javascript克隆元素樣式的實(shí)現(xiàn)代碼

    javascript克隆元素樣式的實(shí)現(xiàn)代碼

    這是一個實(shí)驗(yàn)用的玩意,它可以克隆指定元素的最終樣式,并包裝成一個css類,它還可以證明Oprea 11.10 是個混球
    2011-10-10
  • javascript實(shí)現(xiàn)數(shù)組最大值和最小值的6種方法

    javascript實(shí)現(xiàn)數(shù)組最大值和最小值的6種方法

    比較數(shù)組中數(shù)值的大小是比較常見的操作,本文主要介紹了javascript實(shí)現(xiàn)數(shù)組最大值和最小值的6種方法,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05
  • 使用D3.js制作圖表詳解

    使用D3.js制作圖表詳解

    D3是目前最流行的JavaScript可視化圖表庫之一,D3的圖表類型非常豐富,并且支持SVG格式,因此應(yīng)用十分廣泛,也有很多圖表插件基于D3開發(fā),比如MetricsGraphics.js,在D3上構(gòu)建的數(shù)據(jù)圖表非常強(qiáng)大。
    2017-08-08
  • Javascript設(shè)計(jì)模式之觀察者模式的多個實(shí)現(xiàn)版本實(shí)例

    Javascript設(shè)計(jì)模式之觀察者模式的多個實(shí)現(xiàn)版本實(shí)例

    這篇文章主要介紹了Javascript設(shè)計(jì)模式之觀察者模式的多個實(shí)現(xiàn)版本實(shí)例,本文給出3種實(shí)現(xiàn)版本代碼,同時給出了Jquery實(shí)現(xiàn)版本,需要的朋友可以參考下
    2015-03-03

最新評論