javascript - HTML5 : Reorder the children li of ul by drag and drop, li 元素之间的边框丢失

标签 javascript css html

原名单如下: Normal

拖拽后,如下图: Error

元素 1 和元素 2 已连接,如何解决此问题? 我的意图是通过拖放重新排序列表项。提前致谢。 这是代码

<!DOCTYPE html>
<html>
<head>
    <title>example</title>

    <style type="text/css">
        .main-area {
            margin-left: 10%;
            margin-right: 10%;
            min-width: 600px;
        }

        ul {
            padding-left: 0;
            text-align:center;
        }

        li {
            word-break: break-all;
            display: inline-block;
            width: 400px;
            height: 200px;
            margin-bottom: 3px;
            border-radius: 3px;
            box-shadow: 1px 1px 3px rgba(0, 0, 0, 1);
        }
    </style>
</head>
<body>
    <script>
        // on source element
        function dragstart (ev) {
            ev.dataTransfer.effectAllowed = "move";
            ev.dataTransfer.setData("srcId", ev.currentTarget.id);
            ev.dataTransfer.setDragImage(ev.currentTarget, 0, 0);
        }
        function dragend(ev) {
            ev.dataTransfer.clearData("srcId");
        }

        // on target element
        function dragover(ev) {
            ev.preventDefault();
        }
        function drop(ev) {
            var srcId = ev.dataTransfer.getData("srcId");
            var srcObj = document.getElementById(srcId)
            if(srcObj != ev.currentTarget){
                var list = document.getElementById('list')
                list.insertBefore(srcObj, ev.currentTarget);
            }
        }
    </script>
    <div id='main-area'>
        <ul id='list'>
            <li id='1' draggable="true" ondragstart="dragstart(event)" ondragend="dragend(event)" ondragover="dragover(event)" ondrop="drop(event)">
                111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111
            </li>
            <li id='2' draggable="true" ondragstart="dragstart(event)" ondragend="dragend(event)" ondragover="dragover(event)" ondrop="drop(event)">
                222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222
            </li>
            <li id='3' draggable="true" ondragstart="dragstart(event)" ondragend="dragend(event)" ondragover="dragover(event)" ondrop="drop(event)">
                333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333
            </li>
            <li id='4' draggable="true" ondragstart="dragstart(event)" ondragend="dragend(event)" ondragover="dragover(event)" ondrop="drop(event)">
                444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444444
            </li>
        </ul>
    </div>
</body>
</html>

最佳答案

删除 li 之间的换行符将防止该行为。

Demo

这真的很奇怪,对我来说就像是一个错误。 Here's a similar article

关于javascript - HTML5 : Reorder the children li of ul by drag and drop, li 元素之间的边框丢失,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25520904/

相关文章:

html - 使用 HTTP Post Request 上传文件

javascript - 完全在客户端创建多个浏览器之间的连接

javascript - 什么是|| {} 在 JavaScript 中意味着什么?

加载外部csv文件的javascript库

javascript - 如何使用延迟效果过渡不同的背景颜色

javascript - EmberJS 应用程序中的 Handlebars 不显示任何内容

javascript - 猴子补丁 JavaScript new Date()

javascript - 如何在单击按钮时切换动画

javascript - 在网络日历中定位 div 元素的问题

javascript - javascript 中的 pdf417 条码阅读器/解码器?