您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

HTML5/CSS3 经典案例-无插件拖拽上传图片(二)

2025/1/10 7:41:13发布20次查看
上一篇已经实现了这个项目的整体的html和css:
html5/css3 经典案例-无插件拖拽上传图片(一)
这篇博客直接在上篇的基础上完成,最终效果:
效果图1:
效果图2:
好了,请允许我把图片贴了两遍,方便大家看效果了~
可以看出我们的图片的li的html其实还是挺复杂的,于是我把html文档做了一些修改:
<span style="font-size:12px;"><body> <p id="uploadbox"> </p> <p id="template" class="hidden"> <li> <img src=""/> <span class="progress"></span> <span class="percentage"></span> </li> </p> </body></span>
可以看到我把li的显示,独立写到了一个p#template,默认是hidden的,这样做的好处是什么呢?避免我们每上传一个文件,在js中出现大量的创建元素与赋属性的代码,一般设计比较复杂的html元素的生成,建议使用这种方式,可以简化代码,也利于我们代码的后期维护。
js代码:
<span style="font-size:12px;">/** * user: zhy * date: 14-6-16 * time: 下午11:06 */ var zhanghongyang = {}; zhanghongyang.html5upload = (function () { var _id_upload_box = "uploadbox"; var _class_progress = "progress"; var _class_percentage = "percentage"; var _tip_no_drag = "将文件拖拽至此区域,即可上传!"; var _tip_drag_over = "释放鼠标立即上传!"; var _uploadele = null; /** * 初始化对象与事件 * @private */ function _init() { _uploadele = document.getelementbyid(_id_upload_box); _uploadele.ondragenter = _ondragenter; _uploadele.ondragover = _ondragover; _uploadele.ondragleave = _ondragleave; _uploadele.ondrop = _ondrop; _setstatusnodrag(); }; /** * 正在拖拽状态 * @private */ function _setdragoverstatus() { if (_checkcontatinselements())return; _uploadele.innertext = _tip_drag_over; _uploadele.style.border = "2px dashed #777"; $(_uploadele).css({lineheight: $(_uploadele).height() + "px"}); } /** * 初始化状态 * @private */ function _setstatusnodrag() { if (_checkcontatinselements())return; _uploadele.innertext = _tip_no_drag; _uploadele.style.border = "2px dashed #777"; $(_uploadele).css({lineheight: $(_uploadele).height() + "px"}); } /** * 上传文件 * @private */ function _setdropstatus() { if (_checkcontatinselements())return; _uploadele.innertext = ""; _uploadele.style.border = "1px solid #444"; $(_uploadele).css({lineheight: "1em"}); $(_uploadele).append("<ul></ul>"); }; /** * 判断是否已经上传文件了 * @private */ function _checkcontatinselements() { return !!$(_uploadele).find("li").size(); } /** * 当ondragenter触发 * @private */ function _ondragenter(ev) { _setdragoverstatus(); } /** * 当ondargmove触发 * @private */ function _ondragover(ev) { //ondragover中必须组织事件的默认行为,默认地,无法将数据/元素放置到其他元素中。 ev.preventdefault(); } /** * 当dragleave触发 * @private */ function _ondragleave(ev) { _setstatusnodrag(); } /** * ondrop触发 * @private */ function _ondrop(ev) { //drop 事件的默认行为是以链接形式打开,所以也需要阻止其默认行为。 ev.preventdefault(); _setdropstatus(); //拿到拖入的文件 var files = ev.datatransfer.files; var len = files.length; for (var i = 0; i < len; i++) { //页面上显示需要上传的文件 _showuploadfile(files[i]); } } /** * 页面上显示需要上传的文件 * @private */ function _showuploadfile(file) { var reader = new filereader(); // console.log(file) // console.log(reader); //判断文件类型 if (file.type.match(/image*/)) { reader.onload = function (e) { var formdata = new formdata(); var li = $("#template li").clone(); var img = li.find("img"); var progress = li.find(".progress"); var percentage = li.find(".percentage"); percentage.text("0%"); img.attr("src", e.target.result); $("ul", $(_uploadele)).append(li); $(_uploadele).find("li").size() == 10 && $(_uploadele).width(($(_uploadele).width() + 8) + "px").css("overflow", "auto"); formdata.append("uploadfile", file); //上传文件到服务器 _uploadtoserver(formdata, li, progress, percentage); }; reader.readasdataurl(file); } else { console.log("此" + file.name + "不是图片文件!"); } } /** * 上传文件到服务器 * @private */ function _uploadtoserver(formdata, li, progress, percentage) { var xhr = new xmlhttprequest(); xhr.open("post", "http://localhost:8080/strurts2fileupload/uploadaction", true); xhr.setrequestheader('x-requested-with', 'xmlhttprequest', 'content-type', 'multipart/form-data;'); //html5新增的api,存储了上传过程中的信息 xhr.upload.onprogress = function (e) { var percent = 0; if (e.lengthcomputable) { //更新页面显示效果 percent = 100 * e.loaded / e.total; progress.height(percent ); percentage.text(percent + "%"); percent >= 100 && li.addclass("done"); } }; xhr.send(formdata); } //把init方法公布出去 return{ init: _init } })(); </span>
注释写得很详细,这次没有直接使用字面量创建对象,因为我不希望使用者可以访问所有的方式和变量,使用了简单的闭包,可以看出几乎所有的方法和变量都是_开头,是因为我认为它们是私有的,我也没有公布出来,唯一公布的就是init方法,供使用者调用。整体方法也使用了命名空间,这样和其他伙伴写的js基本不做造成变量相同的问题。
上面的js中用到了html fileapi,这里介绍一下:
1、file对象也就是我们上面使用的:
file
lastmodifieddate: thu dec 26 2013 18:45:08 gmt+0800 (中国标准时间)
name: "yt_key.png"
size: 45524
type: "image/png"
webkitrelativepath: ""
__proto__: file
可以看到包含上面的一些属性,也就是说,如果使用支持html5的浏览器,给input=type设置onchange事件,用户选择图片或者文件后,就可以做出图片的显示或者文件大小和类型的判断。
2、filereader主要用于异步读取文件内容,注意是异步的,上例我们使用了它的readasdataurl的方法,关于datauri的知识可以自己去百度下。
另外还提供了:readastext用于读取文本;readasarraybuffer和readasbinarystring方法;
还提供了一些事件:onloadstart, onload, onprogress ,onerror , onloaded , onabort 有兴趣的可以去一个一个查看。
最后页面调用,大功告成:
<span style="font-size:12px;"> <script type="text/javascript" src="jquery-1.8.3.js"></script> <script type="text/javascript" src="js/html5upload.js"></script> <script type="text/javascript"> window.onload = function () { zhanghongyang.html5upload.init(); } ; </script></span>
以上就是html5/css3 经典案例-无插件拖拽上传图片(二) 的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product