最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-27 20:37:16
文档

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

Javascript&DHTML实例编程(教程)(三)初级实例篇1—上传文件控件实例_基础知识:效果DEMO:http://www.never-online.net/tutorial/js/upload/Javascript & DHTML 实例编程(教程)(三),初级实例篇—上传文件控件实例上章基本上把要交代的基本知识都说了一些,今天终于开始写代码了:D首先来做一个实例,批量上传的UI控件。以后一般做
推荐度:
导读Javascript&DHTML实例编程(教程)(三)初级实例篇1—上传文件控件实例_基础知识:效果DEMO:http://www.never-online.net/tutorial/js/upload/Javascript & DHTML 实例编程(教程)(三),初级实例篇—上传文件控件实例上章基本上把要交代的基本知识都说了一些,今天终于开始写代码了:D首先来做一个实例,批量上传的UI控件。以后一般做


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

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

如果还有不懂的朋友,可以留言给我。
首先看一个成品截图预览:
/Uploads-s/new/2019-09-25-201925/upload_preview.png

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

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

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

整个图可以简单的表示为

/Uploads-s/new/2019-09-25-201925/upload_UML.png

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

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

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

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

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



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

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

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

二、写出add方法的实现


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; //返回
};

三、写出remove方法的实现


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;
}

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


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;
}

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


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;
}

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





//这里是上面我们写的控件代码,这里由于篇幅,我就不再贴了





var o=new upload("uploadConainer");
o.add();


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

2、每添加一个upload就再加一个容器div
...等

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


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; //返回
};

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

"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">


upload control - http://www.never-online.net


//
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();
};
//]]>



batch upload control with javascript



tutorial of DHTML and javascript programming, Power By never-online.net

文档

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

Javascript&DHTML实例编程(教程)(三)初级实例篇1—上传文件控件实例_基础知识:效果DEMO:http://www.never-online.net/tutorial/js/upload/Javascript & DHTML 实例编程(教程)(三),初级实例篇—上传文件控件实例上章基本上把要交代的基本知识都说了一些,今天终于开始写代码了:D首先来做一个实例,批量上传的UI控件。以后一般做
推荐度:
标签: javascript dh 括号
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top