十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
小编给大家分享一下js如何实现简单商品筛选功能,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

js实现商品筛选功能的具体代码如下
应用场景:商品筛选

Document
当写到这里的时候想要把这个事件函数分离出去,但是有参数。于是问题出现
如何将一个带参数的事件函数分离出去???
于是乎:就有了以下两种方法
1、使用bind改变this指向后返回一个不执行的函数
function Aclick(index) {
// 删掉nav
var choose = document.querySelector('.choose');
var nav = document.querySelector(".choose nav");
choose.removeChild(nav);
// 使用stack重新添加
stack[index] = this.innerHTML;
var nav = document.createElement("nav");
for (k = 0; k < stack.length; k++) {
if (stack[k] != "" && stack[k] != undefined) { //略过stack中的空项,重新向nav中添加span
var span = document.createElement("span");
var a = document.createElement("a");
a.innerHTML = "X";
a.href = "javascript:void(0);";
span.innerHTML = stack[k];
a.onclick = function() {
stack[index] = "";
nav.removeChild(this.parentNode);
}
span.appendChild(a);
nav.appendChild(span);
}
}
choose.insertBefore(nav, choose.children[0]);
}2、在注册函数外面套一层函数将注册函数返回
function Bclick(index) {
return function() {
// 删掉nav
var choose = document.querySelector('.choose');
var nav = document.querySelector(".choose nav");
choose.removeChild(nav);
// 使用stack重新添加
stack[index] = this.innerHTML;
var nav = document.createElement("nav");
for (k = 0; k < stack.length; k++) {
if (stack[k] != "" && stack[k] != undefined) { //略过stack中的空项,重新向nav中添加span
var span = document.createElement("span");
var a = document.createElement("a");
a.innerHTML = "X";
a.href = "javascript:void(0);";
span.innerHTML = stack[k];
a.onclick = function() {
stack[index] = "";
nav.removeChild(this.parentNode);
}
span.appendChild(a);
nav.appendChild(span);
}
}
choose.insertBefore(nav, choose.children[0]);
}
}看完了这篇文章,相信你对“js如何实现简单商品筛选功能”有了一定的了解,如果想了解更多相关知识,欢迎关注创新互联行业资讯频道,感谢各位的阅读!