HTML Tabellenspalten verschiebbar machen - Drag'n'Drop?

Status
Für weitere Antworten geschlossen.

CyborgBeta

Captain
Registriert
Jan. 2021
Beiträge
3.249
Huhu, kann man (mithilfe von JavaScript) die Spalten einer HTML-Tabelle durch Drag-and-drop verschiebbar machen?

Zurzeit sieht der Code so aus:

HTML:
<!DOCTYPE html>
<html lang="de">
  <head>
    <meta charset="utf-8" />
    <title>Tabelle</title>
    <style>
      table,
      th,
      td {
        border: solid black 1px;
      }
      td {
        width: 125px;
      }
      main {
        font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
      }
    </style>
  </head>

  <body>
    <header></header>
    <main>
      <div id="div-1"></div>
      <br />
      <div>
        <button
          id="button-1"
          onclick="(function (btn) {
            btn.disabled = true;
            let t = new Date();
            t.setSeconds(t.getSeconds() + 30);
            let inter = setInterval(function() {
              let t2 = new Date();
              if (t2 < t) {
                btn.textContent = 'Kurse aktualisieren! (' + Number((t - t2) / 1000.0).toFixed(1) + ')';
              } else {
                clearInterval(inter);
                btn.textContent = 'Kurse aktualisieren!';
                btn.disabled = false;
              }
            }, 100);
        initTable();
      })(this);
      return false;"
        >
          Kurse aktualisieren!
        </button>
      </div>
      <br />
      <table id="table-1">
        <tr>
          <th>Coin</th>
          <th>Betrag</th>
          <th>Betrag $</th>
          <th>Kurs</th>
          <th>Betrag Neu</th>
        </tr>
      </table>
    </main>
    <footer></footer>
    <script>
      async function getPrices() {
        const response1 = await fetch("https://api.livecoinwatch.com/coins/list", {
          method: "POST",
          headers: {
            "content-type": "application/json",
            "x-api-key": "geheim",
          },
          body: JSON.stringify({
            currency: "USD",
            sort: "rank",
            order: "ascending",
            offset: 0,
            limit: 100,
            meta: false,
          }),
        });
        const jsonData1 = await response1.json();
        console.log(jsonData1);
        return jsonData1;
      }

      /**
       * @param {array} data
       * @param {object} tableRow
       * @param {String} name
       * @param {Number} rate
       */
      function dataPush(data, tableRow, name, rate) {
        data.push({
          tableRow: tableRow,
          name: name,
          rate: rate,
        });
      }

      /**
       * @param {array} data
       */
      function tablePush(data) {
        data.forEach((d) => {
          let row = d.tableRow;
          {
            let c = row.insertCell(0);
            c.textContent = d.name;
          }
          {
            let c = row.insertCell(1);
            c.textContent = round10(d.rate);
          }
          {
            let c = row.insertCell(2);
            c.textContent = round10(d.rate);
          }
          {
            let c = row.insertCell(3);
            c.textContent = round10(d.rate);
          }
          {
            let c = row.insertCell(4);
            let inp = document.createElement("input");
            inp.addEventListener("input", function (evt) {
              if (this.value.length > 0 && Number(this.value) === parseFloat(this.value)) {
                let amount = parseFloat(this.value);
                let usdAmount = amount * d.rate;
                data[0].tableRow.cells[1].textContent = round10(usdAmount);
                data[0].tableRow.cells[2].textContent = round10(usdAmount);
                for (let i = 1; i < data.length; i++) {
                  let row2 = data[i].tableRow;
                  let rate2 = data[i].rate;
                  row2.cells[1].textContent = round10(usdAmount / rate2);
                  row2.cells[2].textContent = round10(usdAmount);
                }
              }
            });
            c.appendChild(inp);
          }
        });
      }

      /**
       * @param {Number} value
       */
      function round10(value) {
        return Number(value).toFixed(10);
      }

      async function initTable() {
        let table = document.getElementById("table-1");
        for (let i = table.rows.length - 1; i > 0; i--) {
          table.deleteRow(i);
        }
        let data = [];
        dataPush(data, table.insertRow(), "$", 1.0);
        (await getPrices()).forEach((p) => {
          dataPush(data, table.insertRow(), p.code.replaceAll("_", ""), parseFloat(p.rate));
        });
        tablePush(data);
        document.getElementById("div-1").textContent = "Stand: " + new Date();
      }

      initTable();
    </script>
  </body>
</html>

Der Benutzer soll die Möglichkeit haben, die Eingabesäule an einen beliebigen Platz zu ziehen.
 
Mit welcher Lib ginge das?

Sorry, dass ich eine geschlossene Frage gestellt hatte. :(
 
Hmm, hab weder ein Parent noch Child div...
 
Dann halt erstellen?
 
  • Gefällt mir
Reaktionen: BeBur
CyborgBeta schrieb:
Hmm, hab weder ein Parent noch Child div...
jetzt muss ich schon fragen: Hast du irgendwie Schimmer von Programmierung bzw. was du da gerade machst oder versuchst du dir einfach was zusammenzustöpseln was du so findest?
Muss man schon wissen. Du bist hier im Programmier-Unterbereich und da geht man erstmal davon aus, dass jemand auch Ahnung hat.
Falls dem nicht so ist, muss man das dazu sagen.
Aber es ist hier jetzt nicht die Regel, dass man dir deinen Code umschreibt, dass er dann für dich passt.
Dass du die Lösung aus dem Link von mir nicht 1:1 reinkopieren kannst, sollte ja wohl klar sein. Das war ein Denkanstoß, wie man sowas realisieren kann. Programmierung ist auch selbst denken, sich ne Lösung und Struktur zu überlegen, wie man etwas realisieren kann. Nicht nur stumpf runtercoden oder ScriptKiddie mäßig fertige Lösungen umzubauen. ;)

Solche Sachen wie StackOverFlow sind hervorragende Anlaufpunkte um sich Ideen zu holen, aber man muss sie natürlich dann selbst adaptieren und zu seiner für den eigenen Code passenden Lösung weiterentwickeln.
 
  • Gefällt mir
Reaktionen: joshim, mental.dIseASe, ni-sc und 2 andere
Mulciber schrieb:
Dann halt erstellen?
Eine Spalte ist doch kein div ...

Bevor noch mehr dumme Vorschläge kommen, bin ich hier raus.

rg88 schrieb:
jetzt muss ich schon fragen: Hast du irgendwie Schimmer von Programmierung bzw. was du da gerade machst
Danke für nichts.
Ergänzung ()

rg88 schrieb:
Aber es ist hier jetzt nicht die Regel, dass man dir deinen Code umschreibt, dass er dann für dich passt.
Dass du die Lösung aus dem Link von mir nicht 1:1 reinkopieren kannst, sollte ja wohl klar sein.

Du hast eine vermeintliche Lösung verlinkt, die auf mein Problem noch nicht einmal anwendbar ist. Was erwartest du denn? Dass ich jetzt auch noch dankbar bin, dass du dir nicht einmal Mühe gegeben hast? Nein, danke ... so sicher nicht.
 
Zuletzt bearbeitet:
  • Gefällt mir
Reaktionen: mental.dIseASe, Mulciber, rg88 und 2 andere
Status
Für weitere Antworten geschlossen.
Zurück
Oben