2017.12.31 JS拖拽本地图片显示

HTML部分

    <div id="img1" class="box1" ondragover="dragOver(event)" ondrop="picture(event)"></div>
    <div id="img2" class="box2" ondragover="dragOver(event)" ondrop="picture(event)"></div>
    <div id="img3" class="box3" ondragover="dragOver(event)" ondrop="picture(event)"></div>
    <div id="img4" class="box4" ondragover="dragOver(event)" ondrop="picture(event)"></div>

CSS样式部分

        div{width: auto;height: 400px;}
        .box1{background-color: lightblue}
        .box2{background-color: lightcoral}
        .box3{background-color: lightcyan}
        .box4{background-color: lightgoldenrodyellow}

JS部分

function dragStart(e) {
    e.dataTransfer.setData("id",e.target.id);//将img的id写入
}

function dragOver(e) {
    e.preventDefault();//阻止拖拽结束的默认行为,会把文件作为链接打开。
}

function drop(e) {
    var id = e.dataTransfer.getData("id");//得到img的id
    var img = document.getElementById(id);//通过id得到img
    var div = document.getElementById(e.target.id);//通过拖拽的目标的id得到要放入的div
    div.appendChild(img);//将img加入div
}

function picture(e) {
    e.preventDefault();//阻止拖拽结束的默认行为,会把文件作为链接打开。
    var id = e.target.id;//得到div的id
    var box = document.getElementById(id);//通过id得到div
    var file = e.dataTransfer.files[0];//得到文件
    var fileReader = new FileReader();
    fileReader.readAsDataURL(file);//将file读为url
    fileReader.onload = function (ev) {//为div添加一个图片,图片路径为拖拽的文件路径
        var img = document.createElement("img");
        img.src = fileReader.result;
        box.appendChild(img);
    }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值