ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

原生JS实现多条件筛选

2021-08-05 20:32:34  阅读:253  来源: 互联网

标签:原生 document span JS className active var 筛选 strong


https://www.jb51.net/article/193662.htm

原生JS实现多条件筛选

本文实例为大家分享了原生JS实现多条件筛选的具体代码,供大家参考,具体内容如下

我在学JS初始看到的教程基本都是JS二级联动查询、三级联动查询;如下图:

但有时并不需要级联查询,如购买商品时:

今天我以慕课网前端样式作为参考做了下面的Demo,基于原生JS

?
12345678910111213141516171819202122232425262728<div id="direction"> <strong>方向:</strong> <span class="active">全部</span> <span>前端</span> <span>后台</span> <span>数据库</span> <span>UI设计</span></div><div id="category"> <strong>分类:</strong> <span class="active">全部</span> <span>HTML/CSS</span> <span>JavaScript</span> <span>jQuery</span> <span>Python</span> <span>Java</span> <span>AngularJS</span></div><div id="type"> <strong>类型:</strong> <span class="active">全部</span> <span>基础</span> <span>案例</span> <span>框架</span> <span>工具</span></div><strong>返回值:</strong><p id="Res"></p>
?
1234567<style> span{display: inline-block;  cursor: pointer; padding: 8px; border: 1px solid #999;} span.active{  background-color: #c14d00; }</style>
?
123456789101112131415161718192021222324252627282930313233343536373839404142434445<script> var dSpan = document.getElementById('direction').getElementsByTagName('span'); var cSpan = document.getElementById('category').getElementsByTagName('span'); var tSpan = document.getElementById('type').getElementsByTagName('span'); var aSpan = document.getElementsByTagName('span'); var oDirection = document.getElementById('direction'); var oCategory = document.getElementById('category'); var oType = document.getElementById('type'); var oRes = document.getElementById('Res'); dSpan[0].className = 'active'; cSpan[0].className = 'active'; tSpan[0].className = 'active'; for(var i=0; i<aSpan.length; i++){  aSpan[i].onclick = function(){   var siblings = this.parentNode.children;   for(var j=0; j<siblings.length; j++){    siblings[j].className = '';   }   this.className = 'active';   if(this.parentNode == oDirection || this.parentNode == oCategory || this.parentNode == oType){    returnRes();   }  } }  function returnRes(){  var o1 = 0, o2 = 0, o3 = 0;  for(var i=0; i<dSpan.length; i++){   if(dSpan[i].className == 'active'){    o1 = i;   }  }  for(var i=0; i<cSpan.length; i++){   if(cSpan[i].className == 'active'){    o2 = i;   }  }  for(var i=0; i<tSpan.length; i++){   if(tSpan[i].className == 'active'){    o3 = i;   }  }  oRes.innerHTML = (dSpan[o1].innerHTML + "," + cSpan[o2].innerHTML + "," + tSpan[o3].innerHTML); }</script>

最后附上效果图:

注:本篇博文是 【无条件】的分类筛选

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

                        <div class="art_xg">
                            <b>您可能感兴趣的文章:</b><ul><li><a href="/article/124840.htm" title="基于JavaScript实现前端数据多条件筛选功能" target="_blank">基于JavaScript实现前端数据多条件筛选功能</a></li><li><a href="/article/107385.htm" title="Vue.js实现多条件筛选、搜索、排序及分页的表格功能" target="_blank">Vue.js实现多条件筛选、搜索、排序及分页的表格功能</a></li><li><a href="/article/103420.htm" title="js实现表格筛选功能" target="_blank">js实现表格筛选功能</a></li><li><a href="/article/116413.htm" title="JS实现商品筛选功能" target="_blank">JS实现商品筛选功能</a></li><li><a href="/article/89574.htm" title="AngularJs页面筛选标签小功能" target="_blank">AngularJs页面筛选标签小功能</a></li><li><a href="/article/173005.htm" title="原生js实现商品筛选功能" target="_blank">原生js实现商品筛选功能</a></li></ul>
                        </div>

                    </div>

标签:原生,document,span,JS,className,active,var,筛选,strong
来源: https://www.cnblogs.com/sunny3158/p/15105236.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有