TP5简单实现类似淘宝多级商品筛选功能(代码示例)

TP5简单实现类似淘宝多级商品筛选功能(代码示例)

内容导读

收集整理的这篇技术教程文章主要介绍了TP5简单实现类似淘宝多级商品筛选功能(代码示例),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3460字,纯文字阅读大概需要5分钟

内容图文

本篇文章给大家带来的内容是关于TP5简单实现类似淘宝多级商品筛选功能(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

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

内容总结

以上是为您收集整理的TP5简单实现类似淘宝多级商品筛选功能(代码示例)全部内容,希望文章能够帮你解决TP5简单实现类似淘宝多级商品筛选功能(代码示例)所遇到的程序开发问题。 如果觉得技术教程内容还不错,欢迎将网站推荐给程序员好友。

内容备注

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。


本文关键词:

联系我们

在线咨询:点击这里给我发消息

邮件:w420220301@qq.com