时间:2021-07-01 10:21:17 帮助过:2人阅读
前几天做项目时,碰到个需求,商品多级分类筛选功能。之前从没做过,查了不少资料,总算实现了。虽然实现的不够优雅,但起码能有效果,心里还是很高兴的。菜鸟有一颗成为大神的心。在这里分享给各位童鞋,欢迎大佬指导一下。
先说下原理:php实现多级筛选主要是利用a链接get传参,把每个标签包含的参数通过a链接传到后台控制器,控制器接收参数后接着再把值赋回给模板,并且根据参数查询对应数据输出给前台。实现起来也不难,讲到这里,感觉刚开始自己完全没有思路的样子真是该打,哈哈...
下面是前台代码示例:
<body>
<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
]); //模板赋值
当然,实际的情况肯定要设条件判断三个值的数据的,根据值的情况设定where条件。例如:
if ($a == 0 && $b == 0 && $c == 0) {//条件全部为空,即显示所有 $where = ''; } elseif ($a == 0 && $b != 0 && $c != 0) {//模式为全部范围,分类和价格单独指定。 $where = ['b'=>$b,'c'=>$c]; }
因为我的代码写的比较冗余,就不献丑了哈...
最后实现的效果是这样:
图中的样式可以在标签里判断,如果页面接收的参数值和当前标签中的值相同,则给标签高亮样式。至此,就是这样,如果有同学有更好的思路,请不吝赐教。
以上就是TP5简单实现类似淘宝多级商品筛选功能(代码示例)的详细内容,更多请关注Gxl网其它相关文章!