PHP.43-TP框架商城应用实例-后台16-商品属性3-库存量管理
2021-07-04 12:06
标签:接收 导入 dmi 调试 func 控制器 error: tar list 库存量管理 思想:为商品的每个多选属性设置库存量!!要把多选属性排列组合分别指定库存量!! 效果如下:【由商品已经添加的属性决定】 1、建表goods_number{goods_id,goods_number,goods_str_id【商品属性id】} 2、在控制器GoodsController.class.php中取出属性值,输出到表单中 注:A:循环输出商品属性时,将二维数组转成三维 B:库存量添加时,约束:前后台,ID必须升序排列。后台存时转升序,同理前台查询也先排序再查。避免前台调用数据时,属性反转的情况 C:修改时,删除原库存量,重新添加 3、在表单goods_number.html中显示 注:A:JS无效,调试出现如下错误:Uncaught ReferenceError: $ is not defined (anonymous function) 解决方法:导入jquery类库 B:在表单页面中循环打印已有库存量 4、在模型类GoodsModel.class.php中处理删除 =》删除商品,库存量一并删除 PHP.43-TP框架商城应用实例-后台16-商品属性3-库存量管理 标签:接收 导入 dmi 调试 func 控制器 error: tar list 原文地址:http://www.cnblogs.com/zixuanfy/p/7119003.htmldrop if exists p39_goods_number;
create table p39_goods_number
(
goods_id mediumint unsigned not null comment ‘商品Id‘,
goods_number mediumint unsigned not null default ‘0‘ comment ‘库存量‘,
goods_attr_id varchar(150) not null comment ‘商品属性表ID{如果有多个,就拼接成字符串保存在这个字段中}‘,
key goods_id(goods_id)
)engine=InnoDB default charset=utf8 comment ‘库存量‘;
// 处理库存量
public function goods_number()
{
//接收商品ID
$id = I(‘get.id‘);
$gnModel = M(‘goods_number‘);
//处理表单
if(IS_POST)
{
// 先删除原库存,再添加,实现修改
$gnModel->where(array(
‘goods_id‘ => array(‘eq‘, $id),
))->delete();
$gaid = I(‘post.goods_attr_id‘);
$gnum = I(‘post.goods_number‘);
//统计数量,计算比例
$cgaid = count($gaid);
$cgnum = count($gnum);
$rate = $cgaid/$cgnum;
//循环库存量
$_i = 0;
foreach ($gnum as $k => $v)
{
$_goodsAttrId = array();
//从商品属性ID数组中取出 $rate 个,循环一次取一个
for($i=0; $i$rate; $i++)
{
$_goodsAttrId[] = $gaid[$_i];
$_i++;
}
//升序排列
sort($_goodsAttrId, SORT_NUMERIC); //以数字的形式排序
//把取出来的商品属性ID转化成字符串
$_goodsAttrId = (string)implode(‘,‘, $_goodsAttrId);
$gnModel->add(array(
‘goods_id‘ => $id,
‘goods_attr_id‘ => $_goodsAttrId,
‘goods_number‘ => $v,
));
}
}
//(库存量修改)先取出这件商品已经设置过的库存量
$gnData = $gnModel->where(array(
‘goods_id‘ => $id,
))->select();
//根据商品ID取出这件商品所有属性的值和根据属性id,取出属性表中的属性名称
$gaModel = M(‘goods_attr‘);
$gaData = $gaModel->field(‘a.*, b.attr_name, b.attr_type‘)
->alias(‘a‘)
->join(‘LEFT JOIN __ATTRIBUTE__ b ON a.attr_id = b.id ‘)
->where(array(
‘goods_id‘ => array(‘eq‘, $id),
‘b.attr_type‘ => array(‘eq‘, ‘可选‘),
))->select();
//处理$gaData数据,将二维转为三维数组:把属性相同的归类
$_gaData = array();
foreach ($gaData as $k => $v)
{
$_gaData[$v[‘attr_name‘]][] = $v; //以属性名称作为下标
}
//var_dump($_gaData);die;
$this->assign(array(
‘gnData‘ => $gnData,
‘gaData‘ => $_gaData,
‘_page_title‘ => ‘库存量管理‘,
‘_page_btn_name‘ => ‘返回列表‘,
‘_page_btn_link‘ => U(‘lst‘),
));
//显示表单
$this->display();
}
上一篇:day34-WEB框架
文章标题:PHP.43-TP框架商城应用实例-后台16-商品属性3-库存量管理
文章链接:http://soscw.com/essay/101725.html