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

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

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

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

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

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

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

整个图可以简单的表示为

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

一)、正如我们上面预览图所见到的,需要三个或以上的新控件。(添加,删除,还有一个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>

(0)

相关推荐

  • JS清空上传控件input(type="file")的值的代码第1/2页

    google找到这样一个解决方法: 在上传控件中插入了值,就只能通过form的reset功能来清空了,但是form里面其他的值也被reset了. 既然可以使用form的reset清空,那就有办法了:新建一个临时form,然后将需要清空的上传控件移入其中,reset之后,再移回原来所在位置,最后删除创建的临时form.js代码:  复制代码 代码如下: var Upload = { clear: function(id){ var up = (typeof id=="string")?d

  • file控件选择上传文件确定后触发的js事件是哪个

    一直以来纠结于这个问题.今天闲来上网搜索了一下这个问题.终于知道答案.是onchange事件.经过本人测试,可用.还有说onpropertychange也可以.经chrome浏览器测试,无效果.不知道是什么原因.

  • JavaScript动态数量的文件上传控件

    js动态数量的文件上传控件实现代码如下所述: <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>动态数量的文件上传</title> <script type="text/javascript" src="

  • 自制的文件上传JS控件可支持IE、chrome、firefox etc

    复制代码 代码如下: (function() { if (window.FileUpload) { return; } window.FileUpload = function (id, url) { this.id = id; this.autoUpload = true; this.url = url; this.maxSize = null; this.extensions = null; this.dropId = null; }; window.FileUpload.prototype

  • JS限制上传图片大小不使用控件在本地实现

    文件上传之前的检测,通常是通过文件名来判断文件类型是否合法,但是要想检测文件的大小很难办到,除非在本地或者使用控件.使用JS可以轻松解决词问题,js在上传图片前判断大小 这个可以用javascript实现,效果...//允许上传图片文件的大小 具体代码如下   复制代码 代码如下: <script language=javascript> var ImgObj=new Image(); //建立一个图像对象 var AllImgExt=".jpg|.jpeg|.gif|.bmp|.p

  • Javascript & DHTML上传文件控件第1/4页

    上章基本上把要交代的基本知识都说了一些,今天终于开始写代码了:D 首先来做一个实例,批量上传的UI控件.以后一般做的示例也是以UI控件为主的.都是封装成Object或者用Function封装成"Class"类. 也许对于单单看前几章的朋友来说这个例子过于深奥了,但是不用担心,一步步来解释应该很快理解的,关键是理解怎么做,而不是怎么写. 首先看一个成品截图预览: 一.接下来我们先说思路,首先定义一个upload"类", 一).这个类的公共访问信息应该有: 1.构造函数

  • 学习使用AngularJS文件上传控件

    前段时间做项目遇到一个需求是上传文件,大概需要实现的样式是这样子的,见下图: 需要同时上传两个文件.并且规定文件格式和文件大小.因为前端框架使用angular,且不想因为一个上传功能又引入一个jquery,所以在网上查找基于angular的上传控件,因为angular还算比较新,貌似都没有太成熟的插件,网上的教程也大多是复制粘贴,总之没起倒多大的作用...但是皇天不负有心人,最后还是让我遇到了这个功能强大的插件,让我有种相见恨晚的感觉呀,依靠官方文档和师兄的帮助,终于搞清楚了基本的使用方法.好东

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

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

  • SpringMVC上传文件的简单实例

    SpringMVC上传文件的简单实例 在使用springMVC进行系统实现时,springMVC默认的解析器里面是没有加入对文件上传的解析的,这可以方便我们实现自己的文件上传.但如果你想使用springMVC对文件上传的解析器来处理文件上传的时候就需要在spring的applicationContext里面加上springMVC提供的MultipartResolver的申明.这样之后,客户端每次进行请求的时候,springMVC都会检查request里面是否包含多媒体信息,如果包含了就会使用Mu

  • 三个思路解决laravel上传文件报错:413 Request Entity Too Large问题

    最近一个项目当中,要求上传图片,并且限制图片大小,虽然在laravel当中已经添加了相关的表单验证来阻止文件过大的上传,然而当提交表单时,还没轮到laravel处理,nginx就先报错了.当你仔细看报错页面时,你会发现有nginx版本信息,经过分析,这报错是因为nginx的默认上传文件大小配置client_max_body_size只有2MB, 基于nginx验证比laravel验证要早,想要友好报错而不是直接显示413 Request Entity Too Large,那么就有三个思路去解决.

  • Android实现上传文件到服务器实例详解

    本实例实现每隔5秒上传一次,通过服务器端获取手机上传过来的文件信息并做相应处理:采用Android+Struts2技术. 一.Android端实现文件上传 1).新建一个Android项目命名为androidUpload,目录结构如下: 2).新建FormFile类,用来封装文件信息 package com.ljq.utils; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundExce

  • vue中实现上传文件给后台实例详解

    FormData 对象的使用: 1.用一些键值对来模拟一系列表单控件:即把form中所有表单元素的name与value组装成 一个queryString 2. 异步上传二进制文件. (ps:说白了就是不使用form表单实现form表单提交数据或文件,如果还是不懂,请自行百度) 实现过程 1.使用type类型为file的input框实现选择文件(顺便记录一下修改input框的默认样式) 2.修改input框的默认样式 3.通过选择文件拿到数据 4.请求接口 以上就是本次关于vue中实现上传文件给后

  • 使用Spring boot + jQuery上传文件(kotlin)功能实例详解

    文件上传也是常见的功能,趁着周末,用Spring boot来实现一遍. 前端部分 前端使用jQuery,这部分并不复杂,jQuery可以读取表单内的文件,这里可以通过formdata对象来组装键值对,formdata这种方式发送表单数据更为灵活.你可以使用它来组织任意的内容,比如使用 formData.append("test1","hello world"); 在kotlin后端就可以使用@RequestParam("test1") greet

  • yii上传文件或图片实例

    1.test.php 复制代码 代码如下: <body><form action="<?php echo $this->createUrl('/test/upload/');?>" method="post" enctype="multipart/form-data"><input type="file" name="file"/><input t

  • js 上传文件预览的简单实例

    1. FILE API html5提供了FIle和FileReader两个方法,可以读取文件信息并读取文件. 2. example <html> <body> <div id="test-image-preview" style="border: 1px solid rgb(204, 204, 204); width: 100%; height: 200px; background-size: contain; background-repeat

  • HttpsURLConnection上传文件流(实例讲解)

    项目需要对接外部接口,将图片文件流发送到外部接口,下面代码就是HttpsURLConnection如何上传文件流: /** * HttpsURLConnection上传文件流 * * @param args * @throws Exception */ public static void main(String[] args) throws Exception { //本地图片 java.io.File file = new java.io.File("/Users/jikukalun/Pic

随机推荐