zoukankan      html  css  js  c++  java
  • 通过拖拽实现添加和删除

    <!DOCTYPE html>
    <html>

    <head>
    <meta name="author" content="Yeeku.H.Lee(CrazyIt.org)" />
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title> 通过拖放实现添加、删除 </title>
    <style type="text/css">
    div>div {
    display: inline-block;
    padding: 10px;
    background-color: #777;
    margin: 3px;
    }
    </style>
    </head>

    <body>
    <div style="600px;border:1px solid black;">
    <h2>将喜欢的小哥哥拖入收藏夹</h2>
    <div draggable="true" ondragstart="dsHandler(event);">江四晴</div>
    <div draggable="true" ondragstart="dsHandler(event);">江老四</div>
    <div draggable="true" ondragstart="dsHandler(event);">饭卡丘</div>
    <div draggable="true" ondragstart="dsHandler(event);">江猪猪</div>
    </div>
    <div id="dest" style="400px;height:260px;
    border:1px solid black;float:left;">
    <h2 οndragleave="return false;">收藏夹</h2>
    </div>
    <img id="gb" draggable="false" src="https://ss0.bdstatic.com/94oJfD_bAAcT8t7mm9GUKT-xh_/timg?image&quality=100&size=b4000_4000&sec=1539358275&di=e69c33500898f1de97ba14e9b19fa296&src=http://img007.hc360.cn/g7/M08/FB/21/wKhQtFP72ACETPP3AAAAANWI-Go407.jpg" alt="垃圾桶" style="float:left;" />
    <script type="text/javascript">
    var dest = document.getElementById("dest");
    // console.log(dest)
    // 开始拖动事件的事件监听器
    var dsHandler = function(evt) {
    console.log('aaas')
    // 将被拖动元素的innerHTML属性值设置成被拖动的数据
    evt.dataTransfer.setData("text/plain", "<item>" + evt.target.innerHTML);
    }
    // console.log(dsHandler)
    dest.ondrop = function(evt) {
    // console.log('aaaa')
    evt.preventDefault();
    var text = evt.dataTransfer.getData("text/plain");
    // 如果该text以<item>开头
    if(text.indexOf("<item>") == 0) {
    // 创建一个新的div元素
    var newEle = document.createElement("div");
    // 以当前时间为该元素生成一个唯一的ID
    newEle.id = new Date().getUTCMilliseconds();
    // 该元素内容为“拖”过来的数据
    newEle.innerHTML = text.substring(6);
    // 设置该元素允许拖动
    newEle.draggable = "true";
    // 为该元素的开始拖动事件指定监听器
    newEle.ondragstart = function(evt) {
    // 将被拖动元素的id属性值设置成被拖动的数据
    evt.dataTransfer.setData("text/plain", "<remove>" + newEle.id);
    }
    dest.appendChild(newEle);
    // console.log('bbb')
    }
    }
    // 当把被拖动元素“放”到垃圾桶上时激发该方法。
    document.getElementById("gb").ondrop = function(evt) {
    var id = evt.dataTransfer.getData("text/plain");
    // 如果id以<remove>开头
    if(id.indexOf("<remove>") == 0) {
    // 根据“拖”过来的数据,获取被拖动的元素
    var target = document.getElementById(id.substring(8));
    // 删除被拖动的元素
    dest.removeChild(target);
    }
    }
    document.ondragover = function(evt) {
    // 取消事件的默认行为
    return false;
    }
    document.ondrop = function(evt) {
    // 取消事件的默认行为
    return false;
    }
    </script>
    </body>
    </html>

  • 相关阅读:
    sql查询
    PHP常用的设计模式
    PHP内存管理和垃圾回收机制
    记一次面试
    获取py文件函数名及动态调用
    正确解决 mysql 导出文件 分隔符 问题
    解决ValueError: cannot convert float NaN to integer
    Python ---接口返回值中文编码问题
    pandas python 读取大文件
    【neo4J】后台关闭后,前端还能打开视图
  • 原文地址:https://www.cnblogs.com/nengnengc-nnc/p/12505331.html
Copyright © 2011-2022 走看看