javascript - 基于data-id的jquery拖放

标签 javascript jquery html drag-and-drop

我是拖放功能的新手。

J查询:

function allowDrop(ev) {
    ev.preventDefault();
}

function drag(ev) {
    var DataId = ev.target.parentNode.getAttribute('data-id');
    alert("Data Id : "+DataId);
    var selected_table =$("#rows .sim-row[data-id='"+DataId+"']");
    //var main_table = selected_table.parentNode;
    alert("Data Id : "+selected_table.html());
    ev.dataTransfer.setData("text",selected_table);
}

function drop(ev) {
    ev.preventDefault();
    var data = ev.dataTransfer.getData("text");
    alert("Data Id : "+data.html());
    ev.target.appendChild(data.clone());
}

HTML 代码:

<div id="content" ondrop="drop(event)" ondragover="allowDrop(event)">
</div>

<div id="rows">
    <table class="sim-row" data-id="1001" id="1001">
        <tr>
            <td class="sim-row-header1 sim-row-edit width100" data-type="title">Main Title</td>                         
        </tr>
     </table>
</div>  

<div class="buttons"  data-id="1001" id="1001" draggable="true" ondragstart="drag(event)" ondrop="drop(event)">
            <img id="image"src="<?php echo base_url()?>assets/invoice/preview/1001.png" alt="title">Title
        </div>

我想实现就像每当我拖放图像时,整个表格必须添加到下面的 div 中

我有多个表格,它们的工作方式就像整个表格将被拖动到 div 中一样。但是图像不能从位置移除。只有它的内容需要克隆或类似。

现在我遇到了以下错误。但不确定为什么会显示该错误。

TypeError: data.html is not a function

我怎样才能做到这一点? 有任何想法吗 ?有什么建议吗?

最佳答案

给您一个解决方案 https://jsfiddle.net/ed5bmth2/1/

allowDrop = function(ev) {
  ev.preventDefault();
}

drag = function(ev) {
  var DataId = ev.target.parentNode.getAttribute('data-id');
  var selected_table =$("#rows .sim-row[data-id='"+DataId+"']");
  ev.dataTransfer.setData("text",DataId);
}

drop = function(ev) {
  ev.preventDefault();
  var data = ev.dataTransfer.getData("text");
  ev.target.appendChild(document.getElementById(data));
}
#content {
  height: 100px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="content" ondrop="drop(event)" ondragover="allowDrop(event)"></div>

<div id="rows">
  <table class="sim-row" data-id="1001" id="1001">
    <tr>
      <td class="sim-row-header1 sim-row-edit width100" data-type="title">Main Title</td>                         
      </tr>
   </table>
</div>  

<div class="buttons"  data-id="1001" id="1001" draggable="true" ondragstart="drag(event)" ondrop="drop(event)">
  <img id="image"src="https://www.w3schools.com/html/img_logo.gif" alt="title">Title
</div>

希望对您有所帮助。

关于javascript - 基于data-id的jquery拖放,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45914926/

相关文章:

javascript - 在 JavaScript 的字符串输出中应用条件语句

html - 新行中第一个和最后一个内联 block 元素的选择器

javascript - 替换图像 src onclick jQuery

javascript - 在nodejs中导出变量时出错

jquery - 有没有办法选择父表单的输入作为指定 id 的子表单?

javascript - 单击后类之间的内容如何放入变量?

css - 绝对定位按钮不会出现在固定标题上

javascript - Contenteditable:防止内部元素被删除

javascript - 如何仅在存在时才需要模块。 react native

javascript - 为动态元素设置不同的属性