HTML5编程实战之三-图片文本(txt)拖拽预览实现代码
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了HTML5编程实战之三-图片文本(txt)拖拽预览实现代码,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2564字,纯文字阅读大概需要4分钟。
内容图文
![HTML5编程实战之三-图片文本(txt)拖拽预览实现代码](/upload/InfoBanner/zyjiaocheng/389/fe85b48654be45e4a7109704b6d80e50.jpg)
本文主要用到的知识
http://www.gxlcms.com/wiki/1118.html" target="_blank">HTML5中的File及FileReader接口
源码
<!DOCTYPE html><html><head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title>HTML5文件拖拽预览Demo</title> <style type="text/css"> h1{ padding:0px; margin:0px; } p#show{ border: 1px solid #ccc; width: 400px; height: 300px; display: -moz-box; display: -webkit-box; -moz-box-align: center; -webkit-box-align: center; -moz-box-pack: center; -webkit-box-pack: center; resize:both; overflow:auto; } p[id^=show]:hover{ border: 1px solid #333; } p#main{ width:100%; } p#successLabel { color:Red; } p#content { display:none; } </style> <script type="text/javascript"> function init() { var dest = document.getElementById("show"); dest.addEventListener("dragover", function(ev) { ev.stopPropagation(); ev.preventDefault(); }, false); dest.addEventListener("dragend", function(ev) { ev.stopPropagation(); ev.preventDefault(); }, false); dest.addEventListener("drop", function (ev) { ev.stopPropagation(); ev.preventDefault(); var file = ev.dataTransfer.files[0]; var reader = new FileReader(); if (file.type.substr(0, 5) == "image") { reader.onload = function (event) { dest.style.background = 'url(' + event.target.result + ') no-repeat center'; dest.innerHTML = ""; }; reader.readAsDataURL(file); } else if (file.type.substr(0, 4) == "text") { reader.readAsText(file); reader.onload = function (f) { dest.innerHTML = "<pre>" + this.result + "</pre>"; dest.style.background = "white"; } } else { dest.innerHTML = "暂不支持此类文件的预览"; dest.style.background = "white"; } }, false); } //设置页面属性,不执行默认处理(拒绝被拖放) document.ondragover = function(e){e.preventDefault();}; document.ondrop = function(e){e.preventDefault();} window.onload=init; </script></head><body> <h1>HTML5文件拖拽预览Demo</h1> <p id="show"> 文件预览区,仅限图片和txt文件 </p></body></html>
主要代码解析
样式部分就不说了,很简单
dragover、dragend、drop是三个与拖拽相关的事件。
dragover表示被拖放的元素正在本元素范围内移动
dragend表示拖放操作结束
drop表示有其他元素被拖放到了本元素中
代码中先分别监听这几个事件,取消浏览器默认的行为,然后利用HTML5中的File及FileReader判断读取拖拽的文件。
如果文件是图片,就用FileReader的readAsDataURL方法将图片读取为DataURL字符串存入内存,并显示在p中。
如果文件是txt文本,就用FileReader的readAsText方法将文件读取为文本(默认为UTF-8格式),放到内存中,然后显示在p中。
以上就是HTML5编程实战之三-图片文本(txt)拖拽预览实现代码的详细内容,更多请关注Gxl网其它相关文章!
内容总结
以上是互联网集市为您收集整理的HTML5编程实战之三-图片文本(txt)拖拽预览实现代码全部内容,希望文章能够帮你解决HTML5编程实战之三-图片文本(txt)拖拽预览实现代码所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。