TP5简单实现相似京东淘宝多级商品筛选功能。

前几天作项目时,碰到个需求,商品多级分类筛选功能。以前从没作过,查了很多资料,总算实现了。虽然实现的不够优雅,但起码能有效果,内心仍是很高兴的。菜鸟有一颗成为大神的心。在这里分享给各位童鞋,欢迎大佬指导一下。
先说下原理: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

相关文章
相关标签/搜索