Since implementing pagination code, my table can't sort by name anymore, nor can it add or delete content.
What am I doing wrong in this code?
Everything was working perfectly fine and then all of the sudden when I was about to turn in the project it stopped working.
I'm sure there is some small mistake that my newbie eyes can't detect..
'use strict'
let movieData = [{ "id": 1, "name": "Network", "genre": "Comedy|Drama", "rating": "68.22" },
{ "id": 2, "name": "Kommissarie Späck", "genre": "Comedy", "rating": "30.65" },
{ "id": 3, "name": "Pirate, The", "genre": "Adventure|Comedy|Musical|Romance", "rating": "98.22" },
{ "id": 4, "name": "Mary and Martha", "genre": "Drama", "rating": "11.15" },
{ "id": 5, "name": "Four Days in September (O Que É Isso, Companheiro?)", "genre": "Drama", "rating": "20.35" },
{ "id": 6, "name": "Sibling Rivalry", "genre": "Comedy", "rating": "5.91" },
{ "id": 7, "name": "Alice in Wonderland", "genre": "Adventure|Children|Fantasy", "rating": "52.69" },
{ "id": 8, "name": "Dead Weekend", "genre": "Comedy|Sci-Fi", "rating": "30.84" },
{ "id": 9, "name": "Top Hat", "genre": "Comedy|Musical|Romance", "rating": "60.06" },
{ "id": 10, "name": "Cleopatra", "genre": "Drama|Romance|War", "rating": "65.39" },
{ "id": 11, "name": "For All Mankind", "genre": "Documentary", "rating": "73.24" },
{ "id": 12, "name": "Messiah of Evil", "genre": "Horror", "rating": "28.9" },
{ "id": 13, "name": "Princess and the Pirate, The", "genre": "Adventure|Comedy|Romance", "rating": "20.41" },
{ "id": 14, "name": "Restrepo", "genre": "Documentary|War", "rating": "71.18" },
{ "id": 15, "name": "Return to the Blue Lagoon", "genre": "Adventure|Romance", "rating": "67.92" },
{ "id": 16, "name": "Convoy", "genre": "Action|Comedy|Drama", "rating": "22.53" },
{ "id": 17, "name": "Perfect", "genre": "Drama|Romance", "rating": "86.25" },
{ "id": 18, "name": "Son of Babylon (Syn Babilonu)", "genre": "Drama", "rating": "26.54" },
{ "id": 19, "name": "Heaven and Earth (Ten to Chi to)", "genre": "Action|Adventure|Drama|War", "rating": "69.39" },
{ "id": 20, "name": "Carcasses", "genre": "Documentary", "rating": "3.72" },
{ "id": 21, "name": "Repentance", "genre": "Drama|Horror|Thriller", "rating": "55.21" },
{ "id": 22, "name": "Loose Change: Second Edition", "genre": "Documentary|Mystery", "rating": "72.22" },
{ "id": 23, "name": "Resurrection Man", "genre": "Drama|Thriller", "rating": "74.68" },
{ "id": 24, "name": "Green Card", "genre": "Comedy|Drama|Romance", "rating": "35.28" },
{ "id": 25, "name": "Micki Maude", "genre": "Comedy", "rating": "2.02" },
{ "id": 26, "name": "Rover, The", "genre": "Crime|Drama", "rating": "18.73" },
{ "id": 27, "name": "Dark Horse (Voksne mennesker)", "genre": "Comedy|Drama|Romance", "rating": "28.19" },
{ "id": 28, "name": "Street Thief", "genre": "Crime|Documentary", "rating": "67.11" },
{ "id": 29, "name": "Woman In Berlin, A (Anonyma - Eine Frau in Berlin)", "genre": "Drama|War", "rating": "13.85" },
{ "id": 30, "name": "Expendables, The", "genre": "Action|Adventure|Thriller", "rating": "92.78" },
{ "id": 31, "name": "American Haunting, An", "genre": "Drama|Horror|Mystery|Thriller", "rating": "54.56" },
{ "id": 32, "name": "Charlotte Gray", "genre": "Drama|Romance", "rating": "2.79" },
{ "id": 33, "name": "Just Bea (Bare Bea)", "genre": "Drama", "rating": "65.83" },
{ "id": 34, "name": "Land Before Time, The", "genre": "Adventure|Animation|Children|Fantasy", "rating": "36.84" },
{ "id": 35, "name": "Mists of Avalon, The", "genre": "Drama|Fantasy", "rating": "25.29" },
{ "id": 36, "name": "Slaughter of the Innocents", "genre": "Crime|Horror|Mystery|Thriller", "rating": "51.11" },
{ "id": 37, "name": "Good Fairy, The", "genre": "Comedy|Romance", "rating": "7.09" },
{ "id": 38, "name": "G.O.R.A.", "genre": "Adventure|Comedy|Sci-Fi", "rating": "54.07" },
{ "id": 39, "name": "Anthony Zimmer", "genre": "Crime|Drama|Romance|Thriller", "rating": "86.28" },
{ "id": 40, "name": "Men in Black (a.k.a. MIB)", "genre": "Action|Comedy|Sci-Fi", "rating": "34.52" },
{ "id": 41, "name": "Slingshot, The (Kådisbellan)", "genre": "Comedy|Drama", "rating": "6.89" },
{ "id": 42, "name": "Look Who's Talking Now", "genre": "Children|Comedy|Romance", "rating": "59.6" },
{ "id": 43, "name": "Rollerball", "genre": "Action|Drama|Sci-Fi", "rating": "36.71" },
{ "id": 44, "name": "The Adventures of Tom Thumb & Thumbelina", "genre": "Animation", "rating": "28.43" },
{ "id": 45, "name": "Gamera the Brave", "genre": "Action|Sci-Fi", "rating": "80.42" },
{ "id": 46, "name": "Liar Liar", "genre": "Comedy", "rating": "44.39" },
{ "id": 47, "name": "Opening Night", "genre": "Drama", "rating": "92.87" },
{ "id": 48, "name": "That's Life", "genre": "Comedy", "rating": "13.72" },
{ "id": 49, "name": "Gendarme Gets Married, The (Le gendarme se marie)", "genre": "Comedy", "rating": "23.41" },
{ "id": 50, "name": "Sealed Cargo", "genre": "Thriller|War", "rating": "13.07" },
{ "id": 51, "name": "Canyon, The", "genre": "Thriller", "rating": "18.15" },
{ "id": 52, "name": "Goal! III", "genre": "Drama|Romance", "rating": "5.56" },
{ "id": 53, "name": "Last Chance: Diary of Comedians, The (Bokutachi no koukan nikki)", "genre": "Comedy|Drama", "rating": "99.05" },
{ "id": 54, "name": "Island in the Sun", "genre": "Drama|Romance", "rating": "38.75" },
{ "id": 55, "name": "Dirty Story", "genre": "Drama", "rating": "57.85" },
{ "id": 56, "name": "These Amazing Shadows", "genre": "Documentary", "rating": "62.32" },
{ "id": 57, "name": "Falling (a.k.a. Fallen)", "genre": "Drama", "rating": "73.01" },
{ "id": 58, "name": "Grandpa for Christmas, A (Bert & Becca)", "genre": "Comedy|Drama", "rating": "66.3" },
{ "id": 59, "name": "Prince Valiant", "genre": "Adventure", "rating": "30.91" },
{ "id": 60, "name": "Desperate Journey", "genre": "Drama|War", "rating": "80.63" },
{ "id": 61, "name": "Petulia", "genre": "Drama", "rating": "44.79" },
{ "id": 62, "name": "Presidio, The", "genre": "Action|Crime|Romance|Thriller", "rating": "15.39" },
{ "id": 63, "name": "Hidden, The", "genre": "Action|Horror|Sci-Fi", "rating": "34.3" },
{ "id": 64, "name": "Three (a.k.a. 3)", "genre": "Comedy|Drama|Romance", "rating": "5.44" },
{ "id": 65, "name": "Roots", "genre": "Drama|War", "rating": "77.54" },
{ "id": 66, "name": "Dragon Eyes", "genre": "Action|Crime|Drama", "rating": "78.55" },
{ "id": 67, "name": "Beautiful Darling", "genre": "Documentary", "rating": "37.4" },
{ "id": 68, "name": "Car Wash", "genre": "Comedy", "rating": "34.36" },
{ "id": 69, "name": "Paradise", "genre": "Adventure|Romance", "rating": "44.39" },
{ "id": 70, "name": "Patent Leather Kid, The", "genre": "Drama", "rating": "73.04" },
{ "id": 71, "name": "Villain, The", "genre": "Comedy|Western", "rating": "99.67" },
{ "id": 72, "name": "Filth", "genre": "Comedy|Crime|Drama", "rating": "8.98" },
{ "id": 73, "name": "Last Frontier, The", "genre": "Western", "rating": "26.45" },
{ "id": 74, "name": "Permanent Record", "genre": "Drama", "rating": "34.68" },
{ "id": 75, "name": "Edge, The", "genre": "Adventure|Drama", "rating": "94.15" },
{ "id": 76, "name": "Curse of the Werewolf, The", "genre": "Drama|Horror|Romance", "rating": "80.23" },
{ "id": 77, "name": "Lonelyhearts", "genre": "Drama|Film-Noir", "rating": "4.95" },
{ "id": 78, "name": "Hate (Haine, La)", "genre": "Crime|Drama", "rating": "11.21" },
{ "id": 79, "name": "Dr. Dolittle: Tail to the Chief", "genre": "Children|Comedy|Fantasy", "rating": "45.07" },
{ "id": 80, "name": "Mary Stevens M.D.", "genre": "Drama", "rating": "38.05" },
{ "id": 81, "name": "Verboten!", "genre": "Action|Romance|War", "rating": "70.5" },
{ "id": 82, "name": "Vassilisa the Beautiful (Vasilisa prekrasnaya)", "genre": "Adventure|Fantasy", "rating": "12.72" },
{ "id": 83, "name": "Harry and the Hendersons", "genre": "Children|Comedy", "rating": "6.85" },
{ "id": 84, "name": "George & A.J.", "genre": "Animation|Children|Comedy", "rating": "60.71" },
{ "id": 85, "name": "Murder Most Foul", "genre": "Comedy|Crime|Drama|Mystery|Thriller", "rating": "75.37" },
{ "id": 86, "name": "Tyler Perry's The Family That Preys", "genre": "Drama", "rating": "5.56" },
{ "id": 87, "name": "Gate of Flesh (Nikutai no mon)", "genre": "Drama", "rating": "26.89" },
{ "id": 88, "name": "Goat, The", "genre": "Comedy", "rating": "33.05" },
{ "id": 89, "name": "Weddings and Babies ", "genre": "Drama|Romance", "rating": "94.08" },
{ "id": 90, "name": "Too Many Girls", "genre": "Comedy|Musical", "rating": "29.05" },
{ "id": 91, "name": "I Killed My Mother (J'ai tué ma mère)", "genre": "Drama", "rating": "10.73" },
{ "id": 92, "name": "Walk in the Clouds, A", "genre": "Drama|Romance", "rating": "6.67" },
{ "id": 93, "name": "Suspiria", "genre": "Horror", "rating": "84.71" },
{ "id": 94, "name": "Alice's Adventures in Wonderland", "genre": "Adventure|Children|Fantasy|Musical", "rating": "8.63" },
{ "id": 95, "name": "Kenny Begins", "genre": "Action|Comedy|Sci-Fi", "rating": "61.57" },
{ "id": 96, "name": "Restoration", "genre": "Drama", "rating": "59.16" },
{ "id": 97, "name": "Love on the Run (Amour en fuite, L')", "genre": "Comedy|Drama|Romance", "rating": "85.47" },
{ "id": 98, "name": "Night of the Living Dead", "genre": "Horror|Sci-Fi|Thriller", "rating": "99.42" },
{ "id": 99, "name": "Poltergeist II: The Other Side", "genre": "Horror|Thriller", "rating": "57.24" },
{ "id": 100, "name": "Maidentrip", "genre": "Documentary", "rating": "81.03" }
];
//Default Sort
function defaultTableSorting(a, b) {
a = a.toLowerCase();
b = b.toLowerCase();
return (a < b) ? -1 : (a > b) ? 1 : 0;
}
movieData.sort(function(a, b) {
return defaultTableSorting(b.name, a.name);
})
//Toggle Sort
function sortTable(n) {
let table, rows, switching, i, x, y, shouldSwitch, dir, switchcount = 0;
table = document.getElementById("tableData");
switching = true;
dir = 'asc';
while (switching) {
switching = false;
rows = table.rows;
for (i = 0; i < (movieData.length - 1); i ) {
shouldSwitch = false;
x = rows[i].getElementsByTagName('td')[n];
y = rows[i 1].getElementsByTagName('td')[n];
if (dir == 'asc') {
if (y.innerHTML.toString() > x.innerHTML.toString()) {
shouldSwitch = true;
break;
}
} else if (dir == 'desc') {
if (y.innerHTML.toString() < x.innerHTML.toString()) {
shouldSwitch = true;
break;
}
}
}
if (shouldSwitch) {
rows[i].parentNode.insertBefore(rows[i 1], rows[i]);
switching = true;
switchcount ;
} else {
if (switchcount == 0 && dir == "asc") {
dir = "desc";
switching = true;
}
}
}
}
//Add row content
function addTableRow() {
let table = document.getElementById('tableData');
let txt = '';
let movieNameInput = document.getElementById('movieName').value;
let movieGenreInput = document.getElementById('movieGenre').value;
let movieRatingInput = document.getElementById('movieRating').value;
let row = table.insertRow();
txt = txt
`<tr><td>${movieNameInput}</td>
<td>${movieGenreInput}</td>
<td>${movieRatingInput}</td></tr>`;
row.innerHTML = txt;
}
// Delete row content
function deleteRow(i) {
movieData.splice(i, 1);
loadTableData(movieData);
};
// Pagination
function loadTableData(movieData, pageSize, pagenumber) {
let movieDataP = movieData.slice((pagenumber - 1) * pageSize, pagenumber * pageSize);
const tableBody = document.getElementById('tableData');
let txt = '';
for (let i = 0; i < movieDataP.length; i ) {
txt = txt `<tr><td>${movieDataP[i].name}</td>
<td>${movieDataP[i].genre}</td><td>${movieDataP[i].rating}</td>
<td><button onclick="deleteRow(${i});">Delete</button>
<button onclick="editRow(${i});">Edit</button></td></tr>`;
}
tableBody.innerHTML = txt;
}
function decreaseTableData(){
let value = parseInt(document.getElementById('pagenumber').value, 10);
value = isNaN(value) ? 0 : value;
value--;
if (value < 1) {
value = 1
}
document.getElementById('pagenumber').value = value;
loadTableData(movieData, 20, value);
}
function increaseTableData(){
let value = parseInt(document.getElementById('pagenumber').value, 10);
value = isNaN(value) ? 0 : value;
value ;
if (value > 5) {
value = 5
}
document.getElementById('pagenumber').value = value;
loadTableData(movieData, 20, value);
}
window.onload = () => {
loadTableData(movieData, 20, 1);
}
xpbody {
color: black;
font-weight: 500;
background-image: url('');
background-size: cover;
background-repeat: repeat;
background-attachment: fixed;
}
table {
border-collapse: collapse;
width: 70%;
text-align: center;
margin: 40px auto;
}
tr,
th {
border: 1px solid #cccccc;
padding: 8px;
font-size: 16px Z;
}
th {
font-weight: bold;
text-transform: uppercase;
color: bisque;
background-color: #444
}
tr:nth-child(even) {
background: rgba(15, 85, 6, 0.438);
}
.name {
background: maroon;
}
.genre {
background-color: rgba(245, 62, 6, 0.658);
}
.action {
background-color: white;
}
.toggler {
cursor: pointer;
user-select: none;
-webkit-user-select: none;
background-color: rgba(240, 101, 50, 0.411)
}
.toggler:hover {
color: whitesmoke;
background-color: rgba(82, 79, 78, 0.568);
transition: ease-in-out .5s;
}
.addremove {
display: flex;
justify-content: center;
align-items: center;
padding-top: 10px;
padding-bottom: 15px;
color: coral;
font-weight: 900;
}
.pageButton {
border: 1px solid black;
padding: 5px;
}
.clickPageNumber {
background-color: lightgrey;
padding: 5px;
margin-left: 2px;
margin-right: 2px;
}
.pagination-block {
text-align: center;
width: 100%;
}
.pagination-block span {
display: inline-block;
}
.pagination-block .pageButton {
background-color: grey;
color: white;
}
.pagination-block span:hover {
cursor: pointer;
}
.opacity {
opacity: 0.5;
}
.outline-none {
outline: none;
user-select: none;
}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel="stylesheet" href="style.css">
<title>Tabela</title>
</head>
<!--TABLE-->
<body>
<div class="container">
<table class="table">
<thead>
<tr>
<th class="toggler" onclick="sortTable(0)">Name</th>
<th class="genre">Genre</th>
<th class="toggler" onclick="sortTable(2)">Rating</th>
<th class="action">Action</th>
</tr>
</thead>
<tbody id="tableData">
</tbody>
</table>
</div>
<br>
<!--ADD/REMOVE BUTTON-->
<div class="addremove">
Name : <input type="text" name="text" id="movieName">
Genre : <input type="text" name="text" id="movieGenre">
Rating : <input type="text" name="rating" id="movieRating">
<button onclick="addTableRow();">Add</button>
</div>
<div class="pagination">
<div class="pagination-block">
<span class="pageButton outline-none" onclick="decreaseTableData()" id="button_prev">Prev</span>
<input type="button" value="1" id="pagenumber"/>
<span class="pageButton outline-none" onclick="increaseTableData()" id="button_next">Next</span>
</div>
</div>
<script src="app.js"></script>
</body>
</html>
<iframe name="sif1" sandbox="allow-forms allow-modals allow-scripts" frameborder="0"></iframe>
CodePudding user response:
For the issue with the delete button:
From the eventHandler of the delete button you are calling loadTableData(movieData)
without a pageSize
or pageNumber
parameter. Thus
let movieDataP = movieData.slice((pagenumber - 1) * pageSize, pagenumber * pageSize);
won't return any elements to display at the page ...
And for your issue with sorting:
Somewhere while you are sorting, an rows[i]
or rows[i 1]
goes out of bounds or points at an undefined
element. Any particular reason, you are not just using the built-in Array.sort
and then recreate the table?
function sortTable(n) {
//data is sorted ascending if for every element
//the element is less then or equal to the next element
let isascending = movieData.every((x, i) => {
let next =movieData[i 1];
if (next === undefined) return true;
switch (n){
case 0:
return x.name.localeCompare(next.name) <= 0;
case 2:
return x.rating <= next.rating;
}
});
movieData.sort((a,b) => {
switch (n) {
case 0:
//if data is currently sorted ascending reverse sortorder
return a.name.localeCompare(b.name) * (isascending ? -1 : 1);
case 2:
return ( a.rating - b.rating) * (isascending ? -1 : 1);
default:
return 0;
}
})
//recreate the table from the sorted array
let value = parseInt(document.getElementById('pagenumber').value, 10);
loadTableData(movieData, 20, value);
}