库存量管理

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

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

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. June 13th 2017 Week 24th Tuesday

    There are no regrets in life, just lessons. 人生中没有后悔,只有教训. Some people can learn from their past mist ...

  2. Snippets代码块分享网站

    复习时,看老师之前贴在网上的一些代码,顺便搜集了一些代码块Snippets分享网站 http://paste.ubuntu.com/ 简约简单,一如既往Linux风,我之前用的也是这款,但已转gite ...

  3. SQL的id奇迹

    SELECT id,name FROM test where name is null and id>=26 limit 26,3 这里26和26没关系,不是id额

  4. cocos2dx-打敌人游戏(一)

    參照视频: http://v.youku.com/v_show/id_XNjk5MzExNDYw.html 1.參照前一篇文章创建新项目: http://blog.csdn.net/simakongc ...

  5. python:协程

    1,如何实现在两个函数之间的切换? def func1(): print(l) yield print(3) yield def func2(): g =func1() next(g) print(2 ...

  6. css relative

    一.relative和absolute相煎关系 relative限制absolute 1.限制left/top/right/bottom定位 如果父元素有relative,只能根据父元素进行定位 2. ...

  7. 检查WIFI是否连接

    查看网络连接 查看WiFi连接状态 (连接- -断开)

  8. NW.js开发环境的搭建

    写在前面: 之前一直在找关于在mac怎么搭建nw.js的开发环境,苦于自己也没有很深入的理解,其实看看官方文档就差不多知道mac下要怎么整了. 官方文档的图: 正题开始: 先去下载一个nw.js的安装 ...

  9. Java字符串常量池是什么?为什么要有这种常量池?

    简单介绍 Java中的字符串常量池(String Pool)是存储在Java堆内存中的字符串池.我们知道String是java中比较特殊的类,我们可以使用new运算符创建String对象,也可以用双引 ...

  10. SyncUI跨设备同步

    SynUI控制代码 <script type="text/javascript"> /* SyncUI script (Learn more at http://syn ...