Html5 拖放上传图片

Html5 拖放上传图片

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

<!DOCTYPE HTML>  
<html>  
<head>  
    <meta charset="utf-8">  
    <title>HTML5 浏览器拖放 | HTML5 Drag and drop</title>  
    <style>  
        #section{font-family: "Georgia", "微软雅黑", "华文中宋";}  
        .container{display:inline-block;min-height:200px;min-width:360px;color:#f30;padding:30px;border:3px solid #ddd;-moz-border-radius:10px;-webkit-border-radius:10px;border-radius:10px;}  
        .preview{max-width:360px;}  
        #files-list{position:absolute;top:0;left:500px;}  
        #list{width:460px;}  
        #list .preview{max-width:250px;}  
        #list p{color:#888;font-size:12px;}  
        #list .green{color:#09c;}  
    </style>  
</head>  
<body>  
  
    <div id="section">  
        <p>把你的图片拖到以下的容器内:</p>  
  
        <div id="container" class="container">  
              
        </div>  
        <div id ="files-list">  
            <p>已经拖进过来的文件:</p>  
            <ul id="list"></ul>  
        </div>  
    </div>  
  
    <script>  
      
    if (window.FileReader) {  
  
        var list = document.getElementById('list'),  
            cnt = document.getElementById('container');  
  
        // 推断是否图片  
        function isImage(type) {  
            switch (type) {  
            case 'image/jpeg':  
            case 'image/png':  
            case 'image/gif':  
            case 'image/bmp':  
            case 'image/jpg':  
                return true;  
            default:  
                return false;  
            }  
        }  
  
        // 处理拖放文件列表  
        function handleFileSelect(evt) {  
            evt.stopPropagation();  
            evt.preventDefault();  
  
            var files = evt.dataTransfer.files;  
  
            for (var i = 0, f; f = files[i]; i++) {  
  
                var t = f.type ? f.type : 'n/a',  
                    reader = new FileReader(),  
                    looks = function (f, img) {  
                        list.innerHTML += '<li><strong>' + f.name + '</strong> (' + t +  
                            ') - ' + f.size + ' bytes<p>' + img + '</p></li>';  
                        cnt.innerHTML = img;  
                    },  
                    isImg = isImage(t),  
                    img;  
  
                // 处理得到的图片  
                if (isImg) {  
                    reader.onload = (function (theFile) {  
                        return function (e) {  
                            img = '<img class="preview" src="' + e.target.result + '" title="' + theFile.name + '"/>';  
                            looks(theFile, img);  
                        };  
                    })(f)  
                    reader.readAsDataURL(f);  
                } else {  
                    img = '"o((>ω< ))o"。你传进来的不是图片!!';  
                    looks(f, img);  
                }  
  
            }  
  
        }  
          
        // 处理插入拖出效果  
        function handleDragEnter(evt){ this.setAttribute('style', 'border-style:dashed;'); }  
        function handleDragLeave(evt){ this.setAttribute('style', ''); }  
  
        // 处理文件拖入事件,防止浏览器默认事件带来的重定向  
        function handleDragOver(evt) {  
            evt.stopPropagation();  
            evt.preventDefault();  
        }  
          
        cnt.addEventListener('dragenter', handleDragEnter, false);  
        cnt.addEventListener('dragover', handleDragOver, false);  
        cnt.addEventListener('drop', handleFileSelect, false);  
        cnt.addEventListener('dragleave', handleDragLeave, false);  
          
    } else {  
        document.getElementById('section').innerHTML = '你的浏览器不支持啊,同学';  
    }  
      
    </script>  
  
      
</body>  
</html>  

版权声明:本文博客原创文章。博客,未经同意,不得转载。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/117457.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • PostMan的安装和使用教程[通俗易懂]

    PostMan的安装和使用教程[通俗易懂]postman的下载官网:https://www.getpostman.com/downloads/创建账号或者用谷歌浏览器账号登录一个demo了解一下我做的是一个app,后台使用java做的,app通过ajax来请求后台,但是我不知道后台有没有请求成功!因此需要一个测试接口的东西测试我做的接口有没有问题我的app里面的ajax是这样写的api.aja…

  • ospf数据库同步过程_OSPF的概念

    ospf数据库同步过程_OSPF的概念OSPF协议之链路数据库同步OSPF如何实现链路状态数据库的同步-链路信息主要包括:1、链路的类型;2、接口IP地址及掩码;3、链路上所连接的邻居路由器;4、链路的带宽(开销)。区别于RIP路由器之间交互的路由信息,OSPF路由器同步的是最原始的链路状态信息,而且对于邻居路由器发来的链路状态信息,仅作转发。最终所有路由器都将拥有一份相同且完整的原始链路状态信息。为…

    2022年10月15日
  • Matlab2017a/b激活license.lic文件[通俗易懂]

    Matlab2017a/b激活license.lic文件[通俗易懂]网络下载的matlab2017a安装好之后激活遇到license.lic不可用的问题,由于2017a的激活文件更新了,我将激活文件直接替换成2017b的完成了激活成功教程。将激活文件拷贝到matlab安装目录中license文件夹内。license.lic文件内容(可直接复制到文本文件,将后缀改成.lic)INCREMENTAerospace_BlocksetM…

  • C语言:字符数组的输入输出

    C语言:字符数组的输入输出目录用printf输出用scanf输入用gets输入用puts输出 用printf输出 输出方法1:printf逐个字符输出。  voidmain(void){   charc[ ]="Iamhappy";     inti;      for(i=0;i&lt;10;i++){ …

  • vmware15最新激活码_通用破解码

    vmware15最新激活码_通用破解码,https://javaforall.cn/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

  • java adminlte 使用_AdminLTE的使用

    java adminlte 使用_AdminLTE的使用第一次听说这个模板,留着以后用1.AdminLTE的必要配置文件2.自定义主题样式(1)在body中设置class。skin-blue:主题颜色,如果引入了_all-skins.min.css,有很多颜色可以选择,如左图,设置为skin-blue默认就为右图的主题样式。sidebar-mini:在AdminLTE.css中可以找到。(2)wrapper设置:AdminLTE…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号