Javascript & DHTML 实例编程(教程)(三)初级实例篇1—上传文件控件实例


Posted in Javascript onJune 02, 2007

效果DEMO:
http://www.never-online.net/tutorial/js/upload/
Javascript & DHTML 实例编程(教程)(三),初级实例篇—上传文件控件实例
上章基本上把要交代的基本知识都说了一些,今天终于开始写代码了:D
首先来做一个实例,批量上传的UI控件。以后一般做的示例也是以UI控件为主的。都是封装成Object或者用Function封装成"Class"类。

也许对于单单看前几章的朋友来说这个例子过于深奥了,但是不用担心,一步步来解释应该很快理解的,关键是理解怎么做,而不是怎么写。

如果还有不懂的朋友,可以留言给我。
首先看一个成品截图预览:

Javascript & DHTML 实例编程(教程)(三)初级实例篇1—上传文件控件实例

一、接下来我们先说思路,首先定义一个upload"类",

一)、这个类的公共访问信息应该有:
1、构造函数中要传递一些必要的参数,比如,在哪个容器构造upload的信息。
2、必须有一个add()方法,用于添加一个upload
3、必须有一个remove()方法,用于删除一个upload

二)、这个类中应该有一些必要的信息,是生成实例本身所具有的信息,(upload对象的一些信息)。
1、得到一共多少个upload信息,
2、一个容器对象,这个对象也是从构造函数中传递。

整个图可以简单的表示为

Javascript & DHTML 实例编程(教程)(三)初级实例篇1—上传文件控件实例

二、我想我们该想想应该用到哪些知识,哪些是熟悉的,哪些是未知的。

一)、正如我们上面预览图所见到的,需要三个或以上的新控件。(添加,删除,还有一个file控件,也或者还有其它的...但至少眼睛见到的就这么多了),既然是新的信息,就会可能用到document.createElement,要添加进一个容器里就可能用到object.appendChild(obj)或者obj.insertBefore()方法。删除也就是obj.parentNode.removeChild(obj)。这些上一章都已经说过了。

二)、既然是控件,肯定得用function或者是一个对象(object)封装起来,对这部分知识,第一章已经简单的说明了

三)、如何组织呢?在上面的思路中也已经有了文字和图示

接下来就动手写:
一)、构造函数,以及基本的代码(伪代码)

<script>
function upload(target/*容器*/
                )
{
  this._cnt = 0; /*计数器*/
  this.target = document.getElementById(target);
};

upload.prototype.add = function () {
  /*
   *生成一个 file
   *生成一个 添加
   *生成一个 删除
   *计数器+1
   */
};

upload.prototype.remove = function () {
  /*
   *删除一个 file
   *删除一个 添加
   *删除一个 删除
   */
};
</script>

二、写出add方法的实现

<script>
upload.prototype.add = function () {
  /*
   *生成一个 file
   */
  var self = this; var cnt = this._cnt;
  var cFile = document.createElement("input");
  cFile.type="file"; cFile.name="upload";
  cFile.id = "upload_file_" +cnt;
  /*
   *生成一个 添加
   */
  var cAdd = document.createElement("span");
  cAdd.innerHTML="添加";
  cAdd.onclick = function () {
    self.add();
  };
  /*
   *生成一个 删除
   */
  var cRemove = document.createElement("span");
  cRemove.innerHTML="删除";
  cRemove.onclick = function () {
    self.remove(cnt);
  };

  cAdd.id = "upload_add_" +cnt;
  cRemove.id = "upload_remove_" +cnt;

  /* 把所有生成的信息添加到容器中 */
  this.target.appendChild(cFile);
  this.target.appendChild(cAdd);
  this.target.appendChild(cRemove);

  /* 计数器+1 */
  this._cnt++;

  return this; //返回
};
</script>

三、写出remove方法的实现

<script>
upload.prototype.remove = function (n) {
  /*
   *删除一个 file
   */
  var a = document.getElementById("upload_file_" +n);
  a.parentNode.removeChild(a);
  /*
   *删除一个 添加
   */
  var a = document.getElementById("upload_add_" +n);
  a.parentNode.removeChild(a);
  /*
   *删除一个 删除
   */
  var a = document.getElementById("upload_remove_" +n);
  a.parentNode.removeChild(a);

  return this;
}
</script>

上面remove方法过于重复,可考虑重新把remove再简化,从而使我们的代码更简短而且易于维护呢?在这里,我们把这个通用功能放到一个函数里,也就是多加一个函数:

<script>
upload.prototype._removeNode = function (id) {
  var a=document.getElementById(id);
  a.parentNode.removeChild(a);
};

upload.prototype.remove = function (n) {
  /*
   *删除一个 file
   */
  this._removeNode("upload_file_" +n);
  /*
   *删除一个 添加
   */
  this._removeNode("upload_add_" +n);
  /*
   *删除一个 删除
   */
  this._removeNode("upload_remove_" +n);

  return this;
}
</script>

四、将代码组合一下,基本上可以算是完成了:D

<script>
function upload(target/*容器*/
                )
{
  this._cnt = 0; /*计数器*/
  this.target = document.getElementById(target);
};

upload.prototype.add = function () {
  /*
   *生成一个 file
   */
  var self = this; var cnt = this._cnt;
  var cFile = document.createElement("input");
  cFile.type="file"; cFile.name="upload";
  cFile.id = "upload_file_" +cnt;
  /*
   *生成一个 添加
   */
  var cAdd = document.createElement("span");
  cAdd.innerHTML="添加";
  cAdd.onclick = function () {
    self.add();
  };
  /*
   *生成一个 删除
   */
  var cRemove = document.createElement("span");
  cRemove.innerHTML="删除";
  cRemove.onclick = function () {
    self.remove(cnt);
  };

  cAdd.id = "upload_add_" +cnt;
  cRemove.id = "upload_remove_" +cnt;

  /* 把所有生成的信息添加到容器中 */
  this.target.appendChild(cFile);
  this.target.appendChild(cAdd);
  this.target.appendChild(cRemove);

  /* 计数器+1 */
  this._cnt++;

  return this; //返回
};

upload.prototype._removeNode = function (id) {
  var a=document.getElementById(id);
  a.parentNode.removeChild(a);
};

upload.prototype.remove = function (n) {
  /*
   *删除一个 file
   */
  this._removeNode("upload_file_" +n);
  /*
   *删除一个 添加
   */
  this._removeNode("upload_add_" +n);
  /*
   *删除一个 删除
   */
  this._removeNode("upload_remove_" +n);

  return this;
}
</script>

五、OK,让我们运行一下这个控件:

<html>
<head>
<script>
//这里是上面我们写的控件代码,这里由于篇幅,我就不再贴了
</script>
</head>
<body>
<div id="uploadContainer"></div>
<script>
var o=new upload("uploadConainer");
o.add();
</script>
</body>
</html>

六、嗯,已经看到效果了吧,但似乎不太理想,全部添加的都粘在一起了,有必要要美化一下。从何处入手?这里可以有很多选择:
1、加一个换行符<br>
2、每添加一个upload就再加一个容器div
...等

我们这里添加一个容器,如果以后还要加什么东西,会更好加一些,修改add:

<script>
upload.prototype.add = function () {
  /*
   *生成一个 file
   */
  var self = this; var cnt = this._cnt;
  var cWrap = document.createElement("div");
  cWrap.id = "upload_wrap_" +cnt;
  var cFile = document.createElement("input");
  cFile.type="file"; cFile.name="upload";
  cFile.id = "upload_file_" +cnt;
  /*
   *生成一个 添加
   */
  var cAdd = document.createElement("span");
  cAdd.innerHTML="添加";
  cAdd.onclick = function () {
    self.add();
  };
  /*
   *生成一个 删除
   */
  var cRemove = document.createElement("span");
  cRemove.innerHTML="删除";
  cRemove.onclick = function () {
    self.remove(cnt);
  };

  cAdd.id = "upload_add_" +cnt;
  cRemove.id = "upload_remove_" +cnt;

  /* 把所有生成的信息添加到容器中 */
  cWrap.appendChild(cFile);
  cWrap.appendChild(cAdd);
  cWrap.appendChild(cRemove);
  this.target.appendChild(cWrap);

  /* 计数器+1 */
  this._cnt++;

  return this; //返回
};
</script>

七、加上CSS美化一下,最后的代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
 <head>
 <title> upload control - http://www.never-online.net </title>
 <style type="text/css" media="all" title="Default">
      * { font-family:Arial; }
      body { font-size:10pt; }
      h1 { }
      #footer { font-size:9pt; margin:20px; }
      span { margin: 3px; text-decoration:underline; cursor:default; }
 </style>
 <script type="text/javascript">
 //<![CDATA[

    function upload(target) {
      this._cnt = 0; 
      this.target = document.getElementById(target);
    };

    upload.prototype.add = function () {

      var self = this; var cnt = this._cnt;
      var cWrap = document.createElement("div");
      cWrap.id = "upload_wrap_" +cnt;
      var cFile = document.createElement("input");
      cFile.type="file"; cFile.name="upload";
      cFile.id = "upload_file_" +cnt;

      var cAdd = document.createElement("span");
      cAdd.innerHTML="添加";
      cAdd.onclick = function () {
        self.add();
      };

      var cRemove = document.createElement("span");
      cRemove.innerHTML="删除";
      cRemove.onclick = function () {
        self.remove(cnt);
      };

      cAdd.id = "upload_add_" +cnt;
      cRemove.id = "upload_remove_" +cnt;

      cWrap.appendChild(cFile);
      cWrap.appendChild(cAdd);
      cWrap.appendChild(cRemove);
      this.target.appendChild(cWrap);
      this._cnt++;

      return this;
    };

    upload.prototype._removeNode = function (id) {
      var a=document.getElementById(id);
      a.parentNode.removeChild(a);
    };

    upload.prototype.remove = function (n) {
      this._removeNode("upload_file_" +n);
      this._removeNode("upload_add_" +n);
      this._removeNode("upload_remove_" +n);
      return this;
    };

    onload = function () {
      var o = new upload("container");
      o.add();
    };
 //]]>
 </script>
 </head>
 <body id="www.never-online.net">
    <h1> batch upload control with javascript </h1>
    <div id="container"></div>
    <div id="footer">tutorial of DHTML and javascript programming, Power By never-online.net</div>
 </body>
</html>

Javascript 相关文章推荐
JavaScript CSS修改学习第五章 给“上传”添加样式
Feb 19 Javascript
分享一个自己写的简单的javascript分页组件
Feb 15 Javascript
javascript实现十秒钟后注册按钮可点击的方法
May 13 Javascript
JSON字符串和对象之间的转换详解
May 26 Javascript
JavaScript实现给按钮加上双重动作的方法
Aug 14 Javascript
使用plupload自定义参数实现多文件上传
Jul 19 Javascript
js实现图片淡入淡出切换简易效果
Aug 22 Javascript
JS通过位运算实现权限加解密
Aug 14 Javascript
深入浅析javascript函数中with
Oct 28 Javascript
JavaScript基于遍历操作实现对象深拷贝功能示例
Mar 05 Javascript
js动态获取时间的方法分析
Aug 02 Javascript
jQuery HTML设置内容和属性操作实例分析
May 20 jQuery
Javascript &amp; DHTML 实例编程(教程)DOM基础和基本API
Jun 02 #Javascript
Javascript &amp; DHTML 实例编程(教程)基础知识
Jun 02 #Javascript
把JS与CSS写在同一个文件里的书写方法
Jun 02 #Javascript
JavaScript 不只是脚本
May 30 #Javascript
JCalendar 日历控件 v1.0 beta[兼容IE&amp;Firefox] 有文档和例子
May 30 #Javascript
[原创]站长必须要知道的javascript广告代码
May 30 #Javascript
JSON 学习之完全手册 图文
May 29 #Javascript
You might like
兼容PHP5的PHP目录管理函数库
2008/07/10 PHP
用php过滤危险html代码的函数
2008/07/22 PHP
解析PHP留言本模块主要功能的函数说明(代码可实现)
2013/06/25 PHP
Drupal7 form表单二次开发要点与实例
2014/03/02 PHP
ThinkPHP调试模式与日志记录概述
2014/08/22 PHP
php实现对象克隆的方法
2015/06/20 PHP
Laravel6.18.19如何优雅的切换发件账户
2020/06/14 PHP
jQuery 顺便学习下CSS选择器 奇偶匹配nth-child(even)
2010/05/24 Javascript
jQuery(1.6.3) 中css方法对浮动的实现缺陷分析
2011/09/09 Javascript
简单实例处理url特殊符号&amp;处理(2种方法)
2013/04/02 Javascript
超链接的禁用属性Disabled使用示例
2014/07/31 Javascript
jquery超简单实现手风琴效果的方法
2015/06/05 Javascript
Node.js中process模块常用的属性和方法
2016/12/13 Javascript
详解如何构建Angular项目目录结构
2017/07/13 Javascript
Node.js模块全局安装路径配置方法
2018/05/17 Javascript
jQuery实现数字自动增加或者减少的动画效果示例
2018/12/11 jQuery
浅谈webpack devtool里的7种SourceMap模式
2019/01/14 Javascript
小程序识别身份证,银行卡,营业执照,驾照的实现
2019/11/05 Javascript
JQuery事件委托(适用于给动态生成的脚本元素添加事件)
2020/02/01 jQuery
Vue状态模式实现窗口停靠功能(灵动、自由, 管理后台Admin界面)
2020/03/06 Javascript
DJANGO-ALLAUTH社交用户系统的安装配置
2014/11/18 Python
Python3.6笔记之将程序运行结果输出到文件的方法
2018/04/22 Python
python爬取网页内容转换为PDF文件
2020/07/28 Python
使用Python做定时任务及时了解互联网动态
2019/05/15 Python
python获取指定日期范围内的每一天,每个月,每季度的方法
2019/08/08 Python
python中threading开启关闭线程操作
2020/05/02 Python
Windows 下更改 jupyterlab 默认启动位置的教程详解
2020/05/18 Python
详解Python中的Lock和Rlock
2021/01/26 Python
python实现控制台输出颜色
2021/03/02 Python
初探CSS3中的calc()功能
2015/07/14 HTML / CSS
椰子猫砂:CatSpot
2018/08/27 全球购物
家长给孩子的评语
2014/01/30 职场文书
《会变的花树叶》教学反思
2014/02/10 职场文书
房屋租赁协议书
2014/10/18 职场文书
SpringBoot+Redis实现布隆过滤器的示例代码
2022/03/17 Java/Android
SpringBoot全局异常处理方案分享
2022/05/25 Java/Android