库存量管理

  思想:为商品的每个多选属性设置库存量!!要把多选属性排列组合分别指定库存量!!

  效果如下:【由商品已经添加的属性决定】

1、建表goods_number{goods_id,goods_number,goods_str_id【商品属性id】}

drop 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 '库存量';

库存量表(goods_number)

2、在控制器GoodsController.class.php中取出属性值,输出到表单中

注:A:循环输出商品属性时,将二维数组转成三维

B:库存量添加时,约束:前后台,ID必须升序排列。后台存时转升序,同理前台查询也先排序再查。避免前台调用数据时,属性反转的情况

C:修改时,删除原库存量,重新添加

    //    处理库存量
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();
}

3、在表单goods_number.html中显示

注:A:JS无效,调试出现如下错误:Uncaught ReferenceError: $ is not defined  (anonymous function)

解决方法:导入jquery类库

B:在表单页面中循环打印已有库存量

<layout name="layout" />

<!-- 库存列表 -->
<div class="list-div" id="listDiv">
<form method="POST" action="__SELF__">
<table cellpadding="3" cellspacing="1">
<tr>
<!-- 循环输出属性 -->
<?php foreach ($gaData as $k => $v): ?>
<th><?php echo $k; ?></th>
<?php endforeach; ?>
<th width="120">库存量</th>
<th width="60">操作</th>
</tr>
<?php if($gnData): ?>
<?php foreach ($gnData as $k0 => $v0): ?>
<tr class="tron">
<?php
$gaCount = count($gaData);
foreach ($gaData as $k => $v): ?>
<td>
<select name="goods_attr_id[]">
<option value="">请选择</option>
<?php foreach ($v as $k1 => $v1):
$_attr = explode(',', $v0['goods_attr_id']);
if(in_array($v1['id'], $_attr))
$select = 'selected="selected"';
else
$select = '';
?>
<option <?php echo $select; ?> value="<?php echo $v1['id']; ?>"><?php echo $v1['attr_value']; ?></option>
<?php endforeach; ?>
</select>
</td>
<?php endforeach; ?>
<td><input type="text" name="goods_number[]" value="<?php echo $v0['goods_number']; ?>" /></td>
<td><input onclick="addNewTr(this);" type="button" value="<?php echo $k0==0?'+':'-'; ?>" /></td>
</tr>
<?php endforeach; ?>
<?php else: ?>
<tr class="tron">
<?php
$gaCount = count($gaData);
foreach ($gaData as $k => $v): ?>
<td>
<select name="goods_attr_id[]">
<option value="">请选择</option>
<?php foreach ($v as $k1 => $v1): ?>
<option value="<?php echo $v1['id']; ?>"><?php echo $v1['attr_value']; ?></option>
<?php endforeach; ?>
</select>
</td>
<?php endforeach; ?>
<td><input type="text" name="goods_number[]" value="" /></td>
<td><input onclick="addNewTr(this);" type="button" value="+" /></td>
</tr>
<?php endif; ?>
<tr id="submit">
<td align="center" colspan="<?php echo $gaCount+2; ?>"><input type="submit" value="提交" /></td>
</tr>
</table>
</form>
</div> <script type="text/javascript" src="__PUB__/umeditor1.2.3-utf8-php/third-party/jquery.min.js"></script>
<script type="text/javascript">
function addNewTr(btn)
{
var tr = $(btn).parent().parent();
if($(btn).val() == "+")
{
var newTr = tr.clone();
newTr.find(":button").val("-");
$("#submit").before(newTr);
}
else
tr.remove(); }
</script>
<script src="__PUB__/Admin/Js/tron.js"></script>

 4、在模型类GoodsModel.class.php中处理删除 =》删除商品,库存量一并删除

PHP.43-TP框架商城应用实例-后台18-商品属性3-库存量管理的更多相关文章

  1. PHP.40-TP框架商城应用实例-后台15-商品属性与库存量1-不同商品(唯一属性、可选属性),属性类型

    思路: 1.不同商品属于不同的类型,如:手机.服装.电脑等类型 2.不同的类型有不同的属性,其中分为唯一属性和可选属性,如服装:可选属性{尺寸:S,M,L……;颜色:白色,黑色……}唯一属性:材质 首 ...

  2. PHP.41-TP框架商城应用实例-后台16-商品属性2-AJAX添加、删除

     添加商品属性 思路:根据[后台15]类型表{id,type_name}与属性表{id,attr_name,attr_type,attr_option_values,type_id} 1.建表商品属性 ...

  3. PHP.42-TP框架商城应用实例-后台17-商品属性3-商品分类的修改与删除

    商品分类的修改 1.改表单Goods/edit.html,加下拉框 2.因为商品属性修改涉及商品属性表goods_attr{id,attr_value,attr_id,goods_id}与属性表att ...

  4. PHP.24-TP框架商城应用实例-后台1-添加商品功能、钩子函数、在线编辑器、过滤XSS、上传图片并生成缩略图

    添加商品功能 1.创建商品控制器[C] /www.test.com/shop/Admin/Controller/GoodsController.class.php <?php namespace ...

  5. PHP.31-TP框架商城应用实例-后台7-商品会员修改-页面优化,多表数据更新

    商品表修改功能 1.页面优化,类似添加页面 <layout name="layout" /> <div class="tab-div"> ...

  6. PHP.48-TP框架商城应用实例-后台23-权限管理-权限验证

    权限验证 1.登录控制器 2.通过tp验证码类生成验证码图片 3.在管理员模型增加登录验证规则 4.后台中所有的控制器必须先登录才能访问 思路:在访问任何一个控制器之前都判断一个session即可,= ...

  7. PHP.28-TP框架商城应用实例-后台5-多表操作-商品表与品牌表

    表与表之间的关系:1:1 1:多 多:多 功能需求决定表关系 此处的表关系为:品牌表:商品表=1:多 1.首先在表结构上关联,在多的表(商品表)添加一个字段,关联一的表(品牌表)的ID(主键) 添加字 ...

  8. PHP.27-TP框架商城应用实例-后台4-使用Gii生成品牌表的代码

    Gii安装[GII适用于商城项目] 将Gii文件夹复到application 是,访问http://xx.com/index.php/gii Gii规则[Gii使用规则与建表规则密切相关] 1.建表字 ...

  9. PHP.44-TP框架商城应用实例-后台19-权限管理-RBAC需求分析

    RBAC:Role Based Access Control:基于角色的访问控制 需求分析:[类似效果如下图] 1.权限,角色,管理员 2.权限管理[无限级] 注意:权限会被分配给角色,而不是给管理员 ...

随机推荐

  1. Git/Github Learning

    通过网上查找资料,我了解到Git/Github是一款免费.开源的分布式版本控制系统,它可以敏捷高效地处理任何或小或大的项目.同时,它是一个开源的分布式版本控制系统,用以有效.高速的处理从很小到非常大的 ...

  2. 推荐一个Chrome扩展应用,能够自动去除CSDN广告

    作为一个程序员,每天编程遇到问题时,少不了前往国内著名的CSDN网站上查信息,看是否有同行遇到类似问题.很多时候根据遇到问题的错误消息进行搜索,结果都是一篇篇CSDN博客.这些博客打开后都会显示很多广 ...

  3. Tomcat与MySQL的数据源连接方法

    Tomcat配置数据源,由于项目经常访问数据库,需要不断地打开关闭,这就耗费了大量的资源.所以用数据源的方式访问数据库. 大体步骤: 配置server.xml 配置项目所在的WebRoot/WEB-I ...

  4. php多进程写入文件

    测试一 $begin = time(); for ($i=0; $i<10000; $i++) { $fp = fopen("tmp", 'r+'); fseek($fp, ...

  5. C语言 字符串处理函数

    #include <stdio.h> #include <string.h> // strlen void test() { // 测量字符串常量的字符长度(不包括\0这个字符 ...

  6. 2019.03.19 ZJOI2019模拟赛 解题报告

    得分: \(100+10+45=155\)(\(T1\)又是水题,\(T2\)写暴力,\(T3\)大力\(STL\)乱搞) \(T1\):哈夫曼树 首先,根据题目中给出的式子,可以发现,我们要求的其实 ...

  7. HDU 4944 逆序数对

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4911 题意: 给出一个序列,可以相邻的交换k次,求 k 次之后,逆序数对最少是多少: 分析: 可以发现 ...

  8. 【题解】P1516 青蛙的约会(Exgcd)

    洛谷P1516:https://www.luogu.org/problemnew/show/P1516 思路: 设两只青蛙跳了T步 则A的坐标为X+mT   B的坐标为Y+nT 要使他们相遇 则满足: ...

  9. 1..net转java背景介绍

    注册博客2年了.从注册就开始接触.net.以前也有想过转java.只是没想过会这么快. .net语法这么优美好用.可惜了生态环境. .net还没有学成大神.就要离开了. 公司有个项目要用java.在加 ...

  10. vuex+vue-router拦截

    干就完了 项目中经常遇到这样一个场景,用户信息或者进行增删改的一些模块,需要根据用户是否登录,进行路由拦截,直接上代码 在store文件夹下的store.js中存放一个默认登录状态 /* * stor ...