From c5b353ed2565427ddd5e976d0a244a89ad52fbb7 Mon Sep 17 00:00:00 2001 From: SACHIN SAINI Date: Tue, 27 Sep 2022 20:22:08 +0530 Subject: [PATCH] added table sorter using JavaScript HTML table sorter using pure JavaScript --- sort html table/index.html | 70 +++++++++++++++++++++++++++ sort html table/script.js | 99 ++++++++++++++++++++++++++++++++++++++ sort html table/style.css | 52 ++++++++++++++++++++ 3 files changed, 221 insertions(+) create mode 100644 sort html table/index.html create mode 100644 sort html table/script.js create mode 100644 sort html table/style.css diff --git a/sort html table/index.html b/sort html table/index.html new file mode 100644 index 0000000..674f3ab --- /dev/null +++ b/sort html table/index.html @@ -0,0 +1,70 @@ + + + + + + + Document + + + + +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Name ScienceMaths Hindi EnglishPhysics
David8588879288
Ramesh9178718174
John8188868492
Tony8488868181
Harish7879878889
+
+ + + diff --git a/sort html table/script.js b/sort html table/script.js new file mode 100644 index 0000000..cc99685 --- /dev/null +++ b/sort html table/script.js @@ -0,0 +1,99 @@ +const table = document.getElementById('sortTable'); +const headers = table.querySelectorAll('th'); +const rows = table.querySelectorAll('tr'); + +headers.forEach((header,headerIndex)=>{ + header.addEventListener('click',()=>{ + sortColumn(headerIndex); + }); +}); + +// Transform the content of given cell in given column +const transform = function (index, content) { + // Get the data type of column + const type = headers[index].getAttribute('type'); + switch (type) { + case 'number': + return parseFloat(content); + case 'string': + default: + return content; + } +}; + +// Track sort directions +let directions = Array(headers.length).fill(""); +console.log(directions); + +function sortColumn(headerIndex){ + + //Check the direction asc or desc + const direction = directions[headerIndex] || 'asc'; + const multiplier = (direction=='asc')? 1 :-1; + changeIcon(direction,headerIndex); + //lets make new instance of rows + let arrayRows = Array.from(rows); + arrayRows.shift();//Exclude header + + let newRows = Array.from(arrayRows); + newRows.sort(function(rowA,rowB){ + //Get the content of cells + const cellA = rowA.querySelectorAll('td')[headerIndex].innerHTML; + const cellB = rowB.querySelectorAll('td')[headerIndex].innerHTML; + let a = transform(headerIndex,cellA); + let b = transform(headerIndex,cellB); + + if(a>b) + return 1*multiplier; + else if(a{ + if(index!=0) + tbody[0].removeChild(row); + }); + //Append new row + newRows.forEach((newRow)=>{ + tbody[0].appendChild(newRow); + }); + + // Reverse the direction + directions[headerIndex] = direction === 'asc' ? 'desc' : 'asc'; + // console.log(directions); +} +function changeIcon(direction,index) +{ + // inactive all icons + for(let i=0;ib) +// { +// return 1; //Place a after b +// } +// else if(a