前几天作项目时,碰到个需求,商品多级分类筛选功能。以前从没作过,查了很多资料,总算实现了。虽然实现的不够优雅,但起码能有效果,内心仍是很高兴的。菜鸟有一颗成为大神的心。在这里分享给各位童鞋,欢迎大佬指导一下。
先说下原理:php实现多级筛选主要是利用a连接get传参,把每一个标签包含的参数经过a连接传到后台控制器,控制器接收参数后接着再把值赋回给模板,而且根据参数查询对应数据输出给前台。实现起来也不难,讲到这里,感受刚开始本身彻底没有思路的样子真是该打,哈哈...
下面是前台代码示例:
<body>php
<div> <span>类型:</span> <!-- 0~4表明ID值 --> <a href="{:url('地址', ['category' => 0, 'mode' => $a, 'price'=>$c])}">所有</a> <a href="{:url('地址', ['category' => 1, 'mode' => $a, 'price'=>$c])}">官方新闻</a> <a href="{:url('地址', ['category' => 2, 'mode' => $a, 'price'=>$c])}">移动应用</a> <a href="{:url('地址', ['category' => 3, 'mode' => $a, 'price'=>$c])}">微信公众号</a> <a href="{:url('地址', ['category' => 4, 'mode' => $a, 'price'=>$c])}">Android开发</a> <span>模式: <a href="{:url('地址', ['category' => $b, 'mode' => '0', 'price'=>$c])}">所有</a> <a href="{:url('地址', ['category' => $b, 'mode' => '1', 'price'=>$c])}">模式1</a> <a href="{:url('地址', ['category' => $b, 'mode' => '2', 'price'=>$c])}">模式2</a> <a href="{:url('地址', ['category' => $b, 'mode' => '3', 'price'=>$c])}">模式3</a> <a href="{:url('地址', ['category' => $b, 'mode' => '4', 'price'=>$c])}">模式4</a> <a href="{:url('地址', ['category' => $b, 'mode' => '5', 'price'=>$c])}">模式5</a> <a href="{:url('地址', ['category' => $b, 'mode' => '6', 'price'=>$c])}">模式6</a> <span>预算价格: <a href="{:url('地址', ['category' => $b, 'mode' => $a, 'price'=>'0'])}">所有</a> <a href="{:url('地址', ['category' => $b, 'mode' => $a, 'price'=>'1'])}">600如下</a> <a href="{:url('地址', ['category' => $b, 'mode' => $a, 'price'=>'600'])}">600-1000</a> <a href="{:url('地址', ['category' => $b, 'mode' => $a, 'price'=>'1000'])}">1000-5000</a> <a href="{:url('地址', ['category' => $b, 'mode' => $a, 'price'=>'5000'])}">5000以上</a> </div>
<!-- 控制把获取过来的参数再赋值给模板 -->
</body>微信
这段代码你们确定都能看懂,我再啰嗦一下,好比当用户第一下点击类型里面的所有的时候,便会把category字段为0传到后台。后台接收判断并把值再赋回给前台,若是category字段值为0,则查询所有的分类数据。若是用户第二下点击模式里面的所有,那此时由于category的值是由后台赋值过来的因此为0,mode为0。若是第三下点击价格里的所有,则三个标签值所有为0。此时后台判断条件,若是所有为0,则所有查询,模板遍历显示。触类旁通,其余标签也是同样。实际操做中,确定不会把值一个一个写在标签里这么傻,只要用volist遍历出来取值就能够了。你们都懂得哈。
由于是多级筛选,因此where方法条件确定不止一个,因此要拼接where方法的值,我是个TPer,用TP5的方法举例:
$b = input('category');//接收的分类id
$a = input('mode'); //接收的模式id
$c = input('price'); //接收的价格范围值
$where = ['category'=>$category,'mode'=>$mode,'price'=>$price];//拼接where条件
$data = model('表名')->where($where)->select(); //查询数据
return $this->fetch('',[
'data'=>$data,
'c'=>$c,
'b'=>$b,
'a'=>$a
]); //模板赋值fetch
固然,实际的状况确定要设条件判断三个值的数据的,根据值的状况设定where条件。例如:this
if ($a == 0 && $b == 0 && $c == 0) {//条件所有为空,即显示全部 $where = ''; } elseif ($a == 0 && $b != 0 && $c != 0) {//模式为所有范围,分类和价格单独指定。 $where = ['b'=>$b,'c'=>$c]; }
由于个人代码写的比较冗余,就不献丑了哈...
最后实现的效果是这样:url
图中的样式能够在标签里判断,若是页面接收的参数值和当前标签中的值相同,则给标签高亮样式。至此,就是这样,若是有同窗有更好的思路,请不吝赐教。spa