从本地磁盘拖拽文件进入html文档中

本文实现从本地磁盘直接拖拽文件进html中。
<h4>html代码部分</h4>

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
        <style type="text/css">
            #wrap{
                width: 300px;
                height: 300px;
                border: 10px solid;
                margin:  0 auto;
                text-align: center;
                line-height: 300px;
                color: rgb(151,151,151);
                font-size: 1.5em;
            }
        </style>
    </head>
    <body>
        <div id="wrap">
            请将上传的文件拖拽进内部
        </div>
    </body>
    <script type="text/javascript">
        var wrap = document.querySelector('#wrap');
        
        wrap.ondragenter = function(){
            this.style.backgroundColor = 'gray';
        }
        wrap.ondragover = function(){
            return false;
            //清理掉标签的dragover默认事件,防止dragover触发时拦截drop事件,直接执行dragend事件。
        }
        wrap.ondragleave = function(){
            this.style.backgroundColor = 'white';
        }
        wrap.ondrop = function (e){
            
            this.style.backgroundColor = 'white';
            var that = this;
            //获取到用户拖拽进来的文件信息
            var file = e.dataTransfer.files[0];
            console.log(file);
            //创建文件读取对象
            var fileReader = new FileReader();
            
            //给对象绑定load事件函数,当对象把路径下的数据读取完毕后,会触发该函数,从该函数中获取到读取的内容
            fileReader.onload = function(e){
                console.log('kkkk');
                //获取读取出来的图片数据
                var data = e.target.result;
//              console.log(data)
                //把图片数据暂存到浏览器中
                that.style.background = 'url('+data+') no-repeat center';
                that.innerHTML = ''
                
            }
            //让读取对象读取用户拖拽的文件的路径
            fileReader.readAsDataURL(file);
            
            
            return false;
//          e.preventDefault();
        }
    </script>
    
    
</html>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 179,507评论 25 708
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 16,026评论 4 61
  • 怨,恚也。——《说文》 说文中明确解释:抱怨就是一种疾病。抱恙的意思:作"病"解,抱恙,即为"抱病",欠安之意。所...
    上官书函阅读 1,863评论 2 6

友情链接更多精彩内容