现在的位置: 首页 > 综合 > 正文

html 动态添加和删除文件选择框及脚本的兼容性问题。

2013年10月12日 ⁄ 综合 ⁄ 共 4352字 ⁄ 字号 评论关闭
 

根据客户的要求,在上传附件的时候,想和平时用的Gmail等一样,可以动态添加和删除文件选择框,然后一次性上传。

从理论上看,实现起来比较容易,但实际工作的时候还是遇到两个难点,这些难点归结起来都是一个原因造成的,那就是浏览器的兼容性。在脚本中要用到两个函数: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,这个函数主要是针对insertAdjacentHTML在firefox下无效的情况重写的,具体可以通过搜索insertAdjacentHTML找到。

来自:http://blog.csdn.net/gaofeng2000/archive/2008/10/22/3125412.aspx#933487

完整的代码:

  1. <html><head>
  2.     <title></title>
  3.     具体两个函数是这样的:
  4. <script type="text/javascript">
  5.     //删除文件选择框
  6.     function removeFile(id) {
  7.         var new_tr = id.parentNode;
  8.         try {
  9.             //new_tr.removeNode(true);
  10.             // just ie , not w3c;
  11.             // other idea
  12.             var tmp = new_tr.parentNode;
  13.             // 为了在ie和firefox下都能正常使用,就要用另一个方法代替,最取上一层的父结点,然后remove.
  14.             tmp.removeChild(new_tr);
  15.          } catch(e) {}
  16.     }
  17.     
  18.     //添加文件选择框
  19.     function addFile(id)
  20.     {
  21.      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>'
  22.      insertHtml("beforeend",document.getElementById(id),str);
  23.       }
  24.        function insertHtml(where, el, html){
  25.         wherewhere = where.toLowerCase();
  26.         if(el.insertAdjacentHTML){
  27.             switch(where){
  28.                 case "beforebegin":
  29.                     el.insertAdjacentHTML('BeforeBegin', html);
  30.                     return el.previousSibling;
  31.                 case "afterbegin":
  32.                     el.insertAdjacentHTML('AfterBegin', html);
  33.                     return el.firstChild;
  34.                 case "beforeend":
  35.                     el.insertAdjacentHTML('BeforeEnd', html);
  36.                     return el.lastChild;
  37.                 case "afterend":
  38.                     el.insertAdjacentHTML('AfterEnd', html);
  39.                     return el.nextSibling;
  40.             }
  41.             throw 'Illegal insertion point -> "' + where + '"';
  42.         }
  43.   var range = el.ownerDocument.createRange();
  44.         var frag;
  45.         switch(where){
  46.              case "beforebegin":
  47.                 range.setStartBefore(el);
  48.                 frag = range.createContextualFragment(html);
  49.                 el.parentNode.insertBefore(frag, el);
  50.                 return el.previousSibling;
  51.              case "afterbegin":
  52.                 if(el.firstChild){
  53.                     range.setStartBefore(el.firstChild);
  54.                     frag = range.createContextualFragment(html);
  55.                     el.insertBefore(frag, el.firstChild);
  56.                     return el.firstChild;
  57.                 }else{
  58.                     el.innerHTML = html;
  59.                     return el.firstChild;
  60.                 }
  61.             case "beforeend":
  62.                 if(el.lastChild){
  63.                     range.setStartAfter(el.lastChild);
  64.                     frag = range.createContextualFragment(html);
  65.                     el.appendChild(frag);
  66.                     return el.lastChild;
  67.                 }else{
  68.                     el.innerHTML = html;
  69.                     return el.lastChild;
  70.                 }
  71.             case "afterend":
  72.                 range.setStartAfter(el);
  73.                 frag = range.createContextualFragment(html);
  74.                 el.parentNode.insertBefore(frag, el.nextSibling);
  75.                 return el.nextSibling;
  76.             }
  77.             throw 'Illegal insertion point -> "' + where + '"';
  78.     }
  79. </script>
  80.     </head>
  81. <body>
  82.     <form name="date_form">
  83.     <div>
  84.         <input type="button" value="添加附件(Add)" onclick="addFile('myfile')">
  85.         </div>
  86.    <div id="myfile">
  87. </div>
  88. </form>
  89. </body>
  90. </html>

抱歉!评论已关闭.