PHP.34-TP框架商城应用实例-后台10-商品分类-需求分析、创建无限级商品分类,递归
商品管理需求分析
1、实现商品无限级分类管理【类似京东三级分类】
2、添加商品时要指定商品属于一个主分类和多个扩展分类【扩展分类可以是其他主分类】
3、商品列表中可以根据分类搜索商品
a) 搜索一个分类小的商品时,这个分类所有子分类下的商品也应该被搜索出来
b) 搜索时要考虑商品的主分类和扩展分类
无限级的商品分类
思路:递归打印树形结构;递归查找分类所有子分类【以便删除时使用】
1、建表
drop table if exists p39_category;
create table p39_category(
id mediumint unsigned not null auto_increment comment 'Id',
cat_name varchar(30) not null comment '分类名称',
parent_id mediumint unsigned not null default '0' comment '上级分类id,0:顶级分类',
primary key(id)
)engine=InnoDB default charset=utf8 comment '分类';
category
2、创建模型CategoryModel.class.php,会用到两种递归函数
注:模型类中要设置添加/修改时允许接收的的字段,和验证字段
//添加调用create方法允许接收的字段
protected $insertFields = array('cate_name', 'parent_id');
//修改调用create方法允许接收的字段
protected $updateFields = array('id', 'cate_name', 'parent_id');
protected $_validate = array(
array('cat_name', 'require', '分类名称不能为空!', 1, 'regex', 3),
);

注:当找到一个分类的所有子分类时,要清空静态变量$_ret,防止再次调用该递归函数时,变量中有值【即限制其只调用一次】

<?php
namespace Admin\Model;
use Think\Model; class CategoryModel extends Model
{
//添加调用create方法允许接收的字段
protected $insertFields = array('cate_name', 'parent_id');
//修改调用create方法允许接收的字段
protected $updateFields = array('id', 'cate_name', 'parent_id');
protected $_validate = array(
array('cat_name', 'require', '分类名称不能为空!', 1, 'regex', 3),
); //递归函数一:找一个分类所有子分类的ID【用于给出某id号,获取其子分类】
public function getChildren($catId)
{
//取出所有的分类
$data = $this->select(); //递归从所有的分类中挑选出子分类的ID
return $this->_getChildren($data, $catId, TRUE);
}
/*****递归从数据中找子分类*****/
private function _getChildren($data, $catId, $isClear = FALSE)
{
static $_ret = array(); //保存找到的子分类的ID
if($isClear) //设标记清零,防止静态变量存储有数据
$_ret = array();
//循环所有分类找子分类
foreach ($data as $k => $v)
{
if($v['parent_id'] == $catId)
{
$_ret[] = $v['id'];
//再找这个$v的子分类
$this->_getChildren($data, $v['id']);
}
}
return $_ret;
} //递归函数二:重新排序数据打印树形数据
public function getTree()
{
$data = $this->select();
var_dump($data);die();
return $this->_getTree($data);
}
/*****递归从数据中找子分类*****/
private function _getTree($data, $parent_id=0, $level=0)
{
static $_ret = array();
foreach ($data as $k => $v)
{
if($v['parent_id'] == $parent_id)
{
$v['level'] = $level; //用来标记这个分类是第几级
$_ret[] = $v;
//找子分类
$this->_getTree($data, $v['id'], $level+1);
}
}
return $_ret;
} }
?>
CategoryModel.class.php
3、创建控制器CategoryController.class.php
利用getTree函数创建分类列表

添加一个商品分类页面lst.html

暂时导入category表数据,做列表测试
INSERT INTO `p39_category` (`id`, `cat_name`, `parent_id`) VALUES
(1, '家用电器', 0),
(2, '手机、数码、京东通信', 0),
(3, '电脑、办公', 0),
(4, '家居、家具、家装、厨具', 0),
(5, '男装、女装、内衣、珠宝', 0),
(6, '个护化妆', 0),
(21, 'iphone', 2),
(8, '运动户外', 0),
(9, '汽车、汽车用品', 0),
(10, '母婴、玩具乐器', 0),
(11, '食品、酒类、生鲜、特产', 0),
(12, '营养保健', 0),
(13, '图书、音像、电子书', 0),
(14, '彩票、旅行、充值、票务', 0),
(15, '理财、众筹、白条、保险', 0),
(16, '大家电', 1),
(17, '生活电器', 1),
(18, '厨房电器', 1),
(19, '个护健康', 1),
(20, '五金家装', 1),
(22, '冰箱', 16);
insert into category

PHP.34-TP框架商城应用实例-后台10-商品分类-需求分析、创建无限级商品分类,递归的更多相关文章
- PHP.24-TP框架商城应用实例-后台1-添加商品功能、钩子函数、在线编辑器、过滤XSS、上传图片并生成缩略图
添加商品功能 1.创建商品控制器[C] /www.test.com/shop/Admin/Controller/GoodsController.class.php <?php namespace ...
- PHP.48-TP框架商城应用实例-后台23-权限管理-权限验证
权限验证 1.登录控制器 2.通过tp验证码类生成验证码图片 3.在管理员模型增加登录验证规则 4.后台中所有的控制器必须先登录才能访问 思路:在访问任何一个控制器之前都判断一个session即可,= ...
- PHP.28-TP框架商城应用实例-后台5-多表操作-商品表与品牌表
表与表之间的关系:1:1 1:多 多:多 功能需求决定表关系 此处的表关系为:品牌表:商品表=1:多 1.首先在表结构上关联,在多的表(商品表)添加一个字段,关联一的表(品牌表)的ID(主键) 添加字 ...
- PHP.27-TP框架商城应用实例-后台4-使用Gii生成品牌表的代码
Gii安装[GII适用于商城项目] 将Gii文件夹复到application 是,访问http://xx.com/index.php/gii Gii规则[Gii使用规则与建表规则密切相关] 1.建表字 ...
- PHP.44-TP框架商城应用实例-后台19-权限管理-RBAC需求分析
RBAC:Role Based Access Control:基于角色的访问控制 需求分析:[类似效果如下图] 1.权限,角色,管理员 2.权限管理[无限级] 注意:权限会被分配给角色,而不是给管理员 ...
- PHP.43-TP框架商城应用实例-后台18-商品属性3-库存量管理
库存量管理 思想:为商品的每个多选属性设置库存量!!要把多选属性排列组合分别指定库存量!! 效果如下:[由商品已经添加的属性决定] 1.建表goods_number{goods_id,goods_nu ...
- PHP.41-TP框架商城应用实例-后台16-商品属性2-AJAX添加、删除
添加商品属性 思路:根据[后台15]类型表{id,type_name}与属性表{id,attr_name,attr_type,attr_option_values,type_id} 1.建表商品属性 ...
- PHP.38-TP框架商城应用实例-后台14-商品管理-商品扩展分类的删除、修改
商品分类删除 1.删除商品时,根据商品id删除扩展分类表数据 商品扩展分类修改 1.在控制器GoodsController.class.php/edit()中根据商品id取出对应的所有扩展分类 2.在 ...
- PHP.33-TP框架商城应用实例-后台9-商品相册-修改、删除(AJAX)
商品相册图片删除 当商品删除时,把相册中的图片一并从硬盘和数据库中删除,根据商品id[因为每一张商品相片都会生成三张缩略图,所以删除时要将其缩略图一并删除] //钩子方法_before_delete: ...
- PHP.31-TP框架商城应用实例-后台7-商品会员修改-页面优化,多表数据更新
商品表修改功能 1.页面优化,类似添加页面 <layout name="layout" /> <div class="tab-div"> ...
随机推荐
- fd_set实现原理
fd_set是一个结构 /* The fd_set member is required to be an array of longs. */ typedef long int __fd_mask; ...
- C#设计模式--适配器模式(结构型模式)
一.适配器模式介绍: 适配器模式:将一个类的接口,转换成客户希望的另外一个接口.adapter模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作 例子分析(充电器充电): 模式中的角色: 安 ...
- 2013应届毕业生各大IT公司待遇整理汇总篇(转)
不管是应届毕业生还是职场中人,在找工作时都必然会对待遇十分关注,而通常都是面试到最后几轮才知道公司给出的待遇.如果我们事先就了解大概行情,那么就会在面试之前进行比较,筛选出几个心仪的公司,这样才能集中 ...
- memcached 的配置及 spymemcached 客户端简单使用
Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.同时也可以用作不同系统之间的数据共享.应用比较广泛.下面介绍一下环境的memcached环境的搭建及简单实 ...
- 使用sqlyog连接ubuntu mysql server错误解决方案
现在很多服务都部署在linux环境中,但是在开发阶段,使用windows远程连接工具,直观,这对开发人员更友好. 下面是我在ubuntu16.04使用mysql- server时,遇到了一下的问题,以 ...
- DIV命名规范
DIV命名规范 企业DIV使用频率高的命名方法 网页内容类 --- 注释的写法: /* Footer */ 内容区/* End Footer */ 摘要: summary 箭头: arrow 商标: ...
- Canvas 中drawImage 绘制不出图片
在使用Canvas的drawImage绘制图片时,却发现绘制不出图片,原因是图片是异步加载,图片加载完再绘制. //html <img src="1.png" /> & ...
- 好的学习网站和app推荐
1 W3cschool: http://www.w3school.com.cn/ 菜鸟教程: http://www.runoob.com/ 2 视频学习网站和app:网易云课堂.腾讯课堂.慕课网(h ...
- 安装和使用nmon监测hadoop集群性能
nmon是一个非常易用的监测Unix/Linux系统性能的小工具,可以在一个屏幕上通过指令切换,显示几乎你想要的所有指标,并且可以自动将指标周期性的保存成 .nmon格式文件,这个工具可以与nmon_ ...
- OpenCV视觉库
视频会议软件的视频质量除了与外置设备.编码器相关外,还与视频的后处理技术相关,视频图像通过后处理技术,如图像增强.图像去噪等,图像质量会得到主观上较大的提高.而我们通常的视频后处理技术会采用开源的项目 ...