3 回答
TA贡献1921条经验 获得超9个赞
好吧,我建议他们做很多改变。不仅是为了性能,也是为了可读性。
首先,我为每个表提供了一个数据属性,稍后我们将使用该属性进行过滤。我还更改了选择框的值以匹配数据集的值。
在 JS 中,我仅选择项目。您在循环的每次迭代中使用 getElementBy
,这意味着 JS 需要多次查看 DOM,我没有使用多个循环,而是将其全部编写在一个循环中。因为它可以一次性完成。
最后我使用了 ES6 语法,因为它允许我使用 const 或 let< /span>解构 和 for of 循环、箭头函数、
// Get the selectbox
const selectBox = document.querySelector("#filterCat");
// Get all the tables
const events = document.querySelectorAll(".event");
// Add eventlistener to trigger whenever the value changes
selectBox.addEventListener("change", () => {
// Get selected value
const { value } = selectBox;
// Loop over each event (table)
for(const event of events) {
// Show the table
event.style.display = "table";
// Continue to the next one if we want to show all tables
if(value === "All") continue;
// Get type from dataset
const { type } = event.dataset;
// If it is not the selected category hide it
if(value !== type) {
event.style.display = "none"
};
}
});
<select class="custom-select mr-sm-2" id="filterCat">
<option selected>All</option>
<option value="concert">Concerts</option>
<option value="sport">Sport</option>
<option value="comedy">Comedy</option>
<option value="theatre">Theatre</option>
<option value="family-attractions">Family attractions</option>
</select>
<table class="event" data-type="concert">
<tr><td>Concert 1</td></tr>
</table>
<table class="event" data-type="sport">
<tr><td>Sport 1</td></tr>
</table>
<table class="event" data-type="comedy">
<tr><td>Comedy 1</td></tr>
</table>
<table class="event" data-type="theatre">
<tr><td>Theatre 1</td></tr>
</table>
<table class="event" data-type="family-attractions">
<tr><td>Family attractions 1</td></tr>
</table>
<table class="event" data-type="concert">
<tr><td>Concert 2</td></tr>
</table>
<table class="event" data-type="sport">
<tr><td>Sport 2</td></tr>
</table>
<table class="event" data-type="comedy">
<tr><td>Comedy 2</td></tr>
</table>
<table class="event" data-type="theatre">
<tr><td>Theatre 2</td></tr>
</table>
<table class="event" data-type="family-attractions">
<tr><td>Family attractions 2</td></tr>
</table>
无评论版本:
const selectBox = document.querySelector("#filterCat");
const events = document.querySelectorAll(".event");
selectBox.addEventListener("change", () => {
const { value } = selectBox;
for(const event of events) {
event.style.display = "table";
if(value === "All") continue;
const { type } = event.dataset;
if(value !== type) {
event.style.display = "none"
};
}
});
<select class="custom-select mr-sm-2" id="filterCat">
<option selected>All</option>
<option value="concert">Concerts</option>
<option value="sport">Sport</option>
<option value="comedy">Comedy</option>
<option value="theatre">Theatre</option>
<option value="family-attractions">Family attractions</option>
</select>
<table class="event" data-type="concert">
<tr><td>Concert 1</td></tr>
</table>
<table class="event" data-type="sport">
<tr><td>Sport 1</td></tr>
</table>
<table class="event" data-type="comedy">
<tr><td>Comedy 1</td></tr>
</table>
<table class="event" data-type="theatre">
<tr><td>Theatre 1</td></tr>
</table>
<table class="event" data-type="family-attractions">
<tr><td>Family attractions 1</td></tr>
</table>
<table class="event" data-type="concert">
<tr><td>Concert 2</td></tr>
</table>
<table class="event" data-type="sport">
<tr><td>Sport 2</td></tr>
</table>
<table class="event" data-type="comedy">
<tr><td>Comedy 2</td></tr>
</table>
<table class="event" data-type="theatre">
<tr><td>Theatre 2</td></tr>
</table>
<table class="event" data-type="family-attractions">
<tr><td>Family attractions 2</td></tr>
</table>
TA贡献1844条经验 获得超8个赞
这是一个更简单的实现。我使用 DIV 代替表格,以保持代码简洁。
function filter_tables() {
var selected = document.getElementById('table-selector').value;
var tables = document.querySelectorAll('.table');
if(selected === 'all') {
tables.forEach( t => { t.className = 'table'; });
} else {
tables.forEach( t => {
if(t.id === 'table'.concat(selected)) {
t.className = 'table';
} else {
t.className = 'table hidden';
}
});
}
}
div.table {
padding: 8px;
margin: 12px;
background-color: yellow;
}
div.table.hidden {
display: none;
}
<select id="table-selector" onchange="filter_tables();">
<option value="all" selected>All</option>
<option value="1">Table 1</option>
<option value="2">Table 2</option>
<option value="3">Table 3</option>
</select>
<div class="table" id="table1">Table 1</div>
<div class="table" id="table2">Table 2</div>
<div class="table" id="table3">Table 3</div>
TA贡献1802条经验 获得超10个赞
var catinput, cat, evinput, events, table, i, t, txtValue, number, num, tableRes, none, no, tableID, tr, td;
number = <?php echo $size['number'] ?>;
您在脚本开头声明每个变量,但有些变量仅在函数或循环中本地使用。 仅在函数中使用的变量应在循环中声明。 在你的脚本中, num, tableRes, ... 必须在循环开始处声明 for (var j = 1; j <= number; j++) {}
另外,您还可以声明一个空变量来立即填充它们。直接给出它们的值。
你的脚本将像这样结束:
<script type="text/javascript">
function filterCategory() {
var evinput, events, i, txtValue, number;
number = <?php echo $size['number'] ?>,
catinput = document.getElementById('filterCat'),
cat = catinput.options[catinput.selectedIndex].text;
t = "table";
for (var j = 1; j <= number; j++) {
var num = j,
tableRes = t.concat(num),
none = document.getElementById(tableRes).style.display;
if (none == "none") {
document.getElementById(tableRes).style.display = "";
}
}
for (var i = 1; i <= number; i++) {
if (cat != "All") {
var no = i,
tableID = t.concat(no),
table = document.getElementById(tableID),
tr = table.getElementsByTagName("tr"),
td = tr[1].getElementsByTagName("td")[0],
txtValue = td.innerText;
if (cat.toUpperCase() != txtValue.toUpperCase()) {
document.getElementById(tableID).style.display = "none";
} else {
document.getElementById(tableID).style.display = "";
}
}
}
}
</script>
- 3 回答
- 0 关注
- 128 浏览
添加回答
举报