js如何实现简单商品筛选功能-创新互联

小编给大家分享一下js如何实现简单商品筛选功能,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

目前创新互联已为上千的企业提供了网站建设、域名、虚拟空间、绵阳服务器托管、企业网站设计、凉城网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。

js实现商品筛选功能的具体代码如下

应用场景:商品筛选

js如何实现简单商品筛选功能





 
 Document
 
 * {
  margin: 0;
  padding: 0;
  list-style: none;
  text-decoration: none;
 }
 
 .choose {
  width: 500px;
  height: auto;
  margin: auto;
 }
 
 .choose nav {
  height: 50px;
  background-color: red;
 }
 
 .choose nav span {
  margin: 0 5px;
 }
 
 .choose .show {
  color: red;
 }
 
 .choose ul li {
  border: 1px solid black;
 }
 
 .choose ul li a {
  box-sizing: border-box;
  display: inline-block;
  width: 40px;
  border-left: 1px solid black;
  margin: 5px;
  padding-left: 5px;
 }
 



 
 
 
      
  •   手机:   小米   华为   apple   OPPO   vivo   
  •   
  •   价格:   3200   2600   899   2799   2299   
  •   
  •   屏幕:   399   600   800   1200   
  •  
 

 var li = document.querySelectorAll('li');
 var stack = []; //存放三个类别的option

 for (var i = 0; i < li.length; i++) {
  // 获取每个li中的option进行处理
  var options = li[i].querySelectorAll("a");
  for (var j = 0; j < options.length; j++) {
  // 当选项被点击时,传入点击的类别是第几个li的
  // options[j].onclick = Aclick.bind(options[j], [i]); //1. 将点击事件分离出去
  options[j].onclick = Bclick(i); //2. 将点击事件分离出去
  }
 }

当写到这里的时候想要把这个事件函数分离出去,但是有参数。于是问题出现

如何将一个带参数的事件函数分离出去???


于是乎:就有了以下两种方法

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如何实现简单商品筛选功能”有了一定的了解,如果想了解更多相关知识,欢迎关注创新互联行业资讯频道,感谢各位的阅读!


本文名称:js如何实现简单商品筛选功能-创新互联
文章转载:http://scyanting.com/article/ddcpdd.html

其他资讯