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>  

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

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • kfold交叉验证好处_sklearn交叉验证

    kfold交叉验证好处_sklearn交叉验证运用Kfold交叉验证时,在一个限度内k的值越大越好。因为k越大我们验证的次数就越多,最后取出来的平均数越能代表训练模型的准确度。但是k是需要在一个限度之内的。k太大有两个坏处。1.容易给机器造成过重负担,花费大量时间。2.每一次验证的测试集(或验证集)中数据太少,很难得到准确的误报率。总体而言,k一般取10,取值依不同项目情况而定,当然一定存在k&lt;n(训练集数据条数)。…

    2022年9月2日
    7
  • 为什么html在浏览器中不能显示图片_做html网页图片显示不出来

    为什么html在浏览器中不能显示图片_做html网页图片显示不出来我遇到的问题是写了一个HTML程序,结果在网页上面不能显示,原因是图片路径放置错了。修改前代码:效果图:ie网页上右键点击“属性”’查看图片路径发现地址错误,我存放图片的地址在C:\Users

    2022年8月2日
    19
  • debian开启ipv6_docker 端口 ipv4 ipv6

    debian开启ipv6_docker 端口 ipv4 ipv6Debian6配置本地IPV6地址访问1、检查自己本地是否支持IPV6,cmd执行命令ipconfig查找有没有ipv6地址,没用的话网上找找怎么配2、vi编辑/etc/sysctl.conf最下面有则修改,无则添加#DisableIPv6net.ipv6.conf.all.disable_ipv6=0net.ipv6.conf.default.disable_ipv…

    2022年8月31日
    2
  • java.lang.NoSuchMethodException: <init>[通俗易懂]

    java.lang.NoSuchMethodException: <init>[通俗易懂]报错信息(捡重要的):java.lang.NoSuchMethodException:com.mmall.pojo.OrderItem.&lt;init&gt;(java.lang.Integer,java.lang.Integer,java.lang.Long,java.lang.Integer,java.lang.String,java.lang.String,java.m…

    2022年6月15日
    40
  • gridview属性_datagridview设置列宽

    gridview属性_datagridview设置列宽usingSystem;usingSystem.Collections.Generic;usingSystem.Text;usingSystem.Drawing;usingSystem.Windows.Forms;classSetDataViewGirdStyle{   privatestaticColor_mLinearBeginColor;

    2022年9月24日
    1
  • 微软hlk服务器密码,Windows HLK 安装程序疑难解答「建议收藏」

    微软hlk服务器密码,Windows HLK 安装程序疑难解答「建议收藏」WindowsHLK安装程序疑难解答10/15/2017本文内容本文包含的信息可帮助你解决Windows硬件实验室工具包(WindowsHLK)安装和设置问题。无法在Studio或客户端计算机上浏览\\\HLKInstall\如果无法从WindowsHLKStudio或客户端浏览到HLKInstall文件夹,请查看在测试服务器上的”步骤1:安装控制器和工作室”主题中…

    2022年5月5日
    90

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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