javascript - 将一个表的数据复制到另一个表时切换按钮

标签 javascript html dom ecmascript-6 html-table

我有两个表 - 一个有列表,另一个是空的收藏夹表。

用户可以在第一个表格中的行上单击“添加”以将它们添加到收藏夹。然后“添加”按钮消失。

收藏夹行呈现为带有“删除”按钮,果然,如果单击,将从收藏夹表中删除该行。

我想做的是,如果从收藏夹表中删除该项目,则该项目的“添加”按钮会重新出现在第一个表中(以便用户可以选择重新添加它),但我想不通了解如何在表之间建立连接以使其正常工作。

// render search results to first table

const renderData = () => {
  tableData.forEach(repo => {
    let row = document.createElement("tr");
    row.className = "resultRow";
    row.innerHTML = `
      <td><a href=${repo.url} target='_blank'>${repo.name}</a></td>
      <td>${repo.language}</td>
      <td>${repo.tag}</td>
      <td class='cell'><button type='button' class='add-btn'>${
        repo.add
      }</button></td>
    `;
    repoTable.appendChild(row);
  });


  // add event listener to 'Add' button. Hide 'Add' button when item is added to favourites

  addBtnArr = Array.from(document.getElementsByClassName("add-btn"));
  addBtnArr.map(i => {
    i.addEventListener("click", () => {
      let userFave = tableData[addBtnArr.indexOf(i)];
      i.style.visibility = 'hidden';
      console.log(userFave)
      addToFavourites(userFave);
    });
  });

};


// copy item to favourites table

const addToFavourites = rowData => {
  console.log(rowData);
  let faveRow = document.createElement("tr");
  faveRow.className = "favesRow";
  rowData.add = "Remove";
  faveRow.innerHTML = `
      <td><a href=${rowData.url} target='_blank'>${rowData.name}</a></td>
      <td>${rowData.language}</td>
      <td>${rowData.tag}</td>
      <td class='cell'><button type='button' class='remove-btn'>${
        rowData.add
      }</button></td>
 `;
  favesTable.appendChild(faveRow);
  hideSingleFave(favesTable);


  // add event listener to 'Remove' button. Remove corresponding row from favourites when clicked

  let removeBtn = Array.from(document.getElementsByClassName("remove-btn"));
  removeBtn.map(i => {
    i.addEventListener("click", () => {
      i.parentElement.parentElement.remove();
    });
  });
};

最佳答案

您可以采用以下方法。为第一个表中的每个 Add Button 添加一个唯一标识它的 id。类似于 index-add,因此您的按钮将具有 0-add、1-add、2-add 等 ID。

当您单击一个按钮时,将隐藏类应用于该按钮。说如果你点击 0-add class hidden 将被添加到它会隐藏按钮。 删除按钮中的 data-add-target = "0-add"。当您单击删除按钮时,读取 data-add-target 属性并删除从该目标按钮隐藏的类。

基本上你的按钮看起来像

<button id="0-add">Add</button>

单击此按钮后,它会隐藏起来,在收藏夹表中,会出现一行带有删除按钮

<button id="0-add" class = "hidden">Add</button>
<button data-add-target="0-add">Remove</button>

单击删除按钮后,从 data-add-target 中删除隐藏类。

<button id="0-add">Add</button>

关于javascript - 将一个表的数据复制到另一个表时切换按钮,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52452350/

相关文章:

javascript - 使用HTML5 canvas的所有浏览器中的无效混合结果

jquery - 图像属性是 DOM 的一部分吗(jQuery - webkit 与其他浏览器不一致)?

javascript - 将 CSS 值设置为 javascript 变量

html - 一旦元素被另一个元素覆盖,可点击事件不再触发

javascript - Angular 5 - 动画不起作用

javascript - Contenteditable 添加带有事件的内容而不替换

javascript - 需要使用 localStorage 创建 JSON

javascript - 如何在没有 Firebase Firestore 解析集合中数据的情况下获取所有文档的 id?

html - 当高度为 : 100% doesn't work 时将 div 设置为 100% 高度

html - CSS 2 Floating Div Inside Container 全高带/图像