1.1:创建表结构

新建三张商品关联的表,表模型如下:

创建SQL语句略

1.2:生成表Model(生成方法见上一节)

1.3:生成tb_ProductType的单结构界面然后添加到项目中

1.4:修改GZVIP.Dictionary模块中DictionaryMain类,新增产品类型功能

public class DictionaryMain : ModuleFunctionManage
{ public DictionaryMain()
{
FunPools.AddFunction(typeof(frm_Level), "等级管理", "Level");
FunPools.AddFunction(

typeof(frm_ProductType), "产品类型", "ProductType"

);
}
}

Image添加如下三个图片如下

相应修改frm_ProductType界面

运行重新加载字典管理DLL结果如下:

至此:商品类型添加完毕

接下来生成商品管理

2.1生成tb_Product表的但结构界面并附加到项目

对界面做一些简单设置:

切换到后台代码修改Load代码(红色部分):

private void frm_Product_Load(object sender, EventArgs e)
{
_SummaryView = gv_Summary;
gv_Summary.OptionsView.ColumnAutoWidth = false;
//_bll = new bllBusiness(typeof(tb_Product),"P",4);

_bll = new bllBusiness<tb_Product>("P", , typeof

(tb_ProductPrice));
//添加只读列
base.AddControlsOnlyRead(txtCreateUser,txtCreateDate,txtLastUpdateUser,txtLastUpdateDate);
//只有新增状态下才可用
base.AddControlsOnAddKey(); this.BoundDatasource();
}

修改DoBoundEditData方法

//绑定明细编辑页的数据
public override void DoBoundEditData()
{
//base.DoBoundEditData();

LibraryTools.DoBindingEditorPanel(layoutControl1, EditData.Tables[_bll.SummaryTableName], "txt"

);
gc_Detail.DataSource

=

 EditData.Tables[tb_ProductPrice._TableName];
}

编辑数据编辑页增加按钮和删除按钮两个按钮的点击事件

       //明细表增加
private void btn_DetailAdd_Click(object sender, EventArgs e)
{
//新增一条记录,并设置商品编号
DataRow dr = EditData.Tables[tb_ProductPrice._TableName].Rows.Add();
dr[tb_ProductPrice.ProductID] = txtProductID.EditValue;
}
//明细表删除
private void btn_DetailDelete_Click(object sender, EventArgs e)
{
if (gv_Detail.FocusedRowHandle < ) return;
if (Msg.AskQuestion("确定要删除选中的价格记录吗?") == false) return;
gv_Detail.DeleteSelectedRows();
}

修改DictionaryMain类

public class DictionaryMain : ModuleFunctionManage
{
public DictionaryMain()
{
FunPools.AddFunction(typeof(frm_Level), "等级管理", "Level");
FunPools.AddFunction(typeof(frm_ProductType), "商品类型", "ProductType");
FunPools.AddFunction(

typeof(frm_Product), "商品管理", "Product"

);
}
}

2.2添加产品类别绑定

修改GZVIP.BLL.DastaCache类,增加ProductType只读属性

/// <summary>
/// 产品类别
/// </summary>
public DataTable ProductType
{
get
{
DataTable dt = CommonData.FindFromCache(tb_ProductType._TableName);
if (dt == null)
{
dt = bllDataCommon.GetAllDataTable(tb_ProductType._TableName, Loginer.CurrentLoginer.SystemDBName
, tb_ProductType.ProductTypeID, tb_ProductType.ProductTypeName);
AddToCache(dt.Copy());
}
return dt;
}
}

修改GZVIP.Library.BouindData类,增加BoundProductType()静态方法

/// <summary>
/// 绑定商品类别
/// </summary>
/// <param name="lue"></param>
/// <param name="displayCombination"></param>
/// <param name="ADDNULL"></param>
public static void BoundProductType(LookUpEdit lue, bool displayCombination, bool ADDNULL)
{
lue.Properties.Columns.Clear();
InitializeControl(lue, new string[] { "编号", "名称" }, new string[] { tb_ProductType.ProductTypeID, tb_ProductType.ProductTypeName });
lue.Properties.Columns[].Width = ;
lue.Properties.Columns[].Width = ;
lue.Properties.PopupWidth = ; DataTable dt = DataCache.Cache.ProductType.Copy();
if (ADDNULL) dt = Common.ADDNULL(dt); string displayMember = tb_ProductType.ProductTypeName;
if (displayCombination)
{
Common.AddColumns(dt, tb_ProductType.ProductTypeID, tb_ProductType.ProductTypeName);
displayMember = Common.DefNewColName;
}
DataBinder.BindingLookupEditDataSource(lue, dt, displayMember, tb_ProductType.ProductTypeID);
} /// <summary>
/// 绑定商品类别
/// </summary>
/// <param name="lue"></param>
/// <param name="displayCombination"></param>
/// <param name="ADDNULL"></param>
public static void BoundProductType(CheckedComboBoxEdit lue, bool displayCombination, bool ADDNULL)
{
DataTable dt = DataCache.Cache.ProductType.Copy();
if (ADDNULL) dt = Common.ADDNULL(dt); string displayMember = tb_ProductType.ProductTypeName;
if (displayCombination)
{
Common.AddColumns(dt, tb_ProductType.ProductTypeID, tb_ProductType.ProductTypeName);
displayMember = Common.DefNewColName;
}
DataBinder.BindingCheckedComboBoxSource(lue, dt, displayMember, tb_ProductType.ProductTypeID);
}

在frm_Product的Load事件中添加数据源绑定

private void frm_Product_Load(object sender, EventArgs e)
{
_SummaryView = gv_Summary;
gv_Summary.OptionsView.ColumnAutoWidth = false;
//_bll = new bllBusiness(typeof(tb_Product),"P",4);
_bll = new bllBusiness<tb_Product>("P", , typeof(tb_ProductPrice));
//添加只读列
base.AddControlsOnlyRead(txtCreateUser,txtCreateDate,txtLastUpdateUser,txtLastUpdateDate);
//只有新增状态下才可用
base.AddControlsOnAddKey(); this.BoundDatasource();
} private void BoundDatasource()
{
DataBinderTools.Bound.BoundUserName(lue_UserName);
DataBinderTools.Bound.BoundUserName(txtCreateUser);
DataBinderTools.Bound.BoundUserName(txtLastUpdateUser); DataBinderTools.Bound.BoundProductType(txt_ProductType, false, true);
DataBinderTools.Bound.BoundProductType(txtProductTypeID, true, true);
}

重写ValidateBeforSave方法,用于保存前验证

//保存前数据验证
protected override bool ValidateBeforSave()
{ bool Validate = true &
CommonTools.IsNotEmpBaseEdit(txtProductName, "产品名称不能为空!")
& CommonTools.IsNotEmpBaseEdit(txtProductTypeID, "产品类别编号不能为空!")
& CommonTools.IsNotEmpBaseEdit(txtProductPrice, "默认价格不能为空!");
//if (Validate == false) return;
if (Validate == true)
EditData.Tables[tb_Product._TableName].Rows[][tb_Product.ProductTypeName] = (txtProductTypeID.GetSelectedDataRow() as DataRowView).Row[tb_ProductType.ProductTypeName];
return Validate;
}

重写SetControlAccessable方法,修改状态改变的时候

/// <summary>
/// 设置按钮可用状态,如果已经在ControlOnlyReads或SetControlAccessable中添加,这里不需要重新设置
/// </summary>
/// <param name="Edit"></param>
protected override void SetControlAccessable(bool Edit)
{
//LibraryTools.SetControlAccessable(tp_Edit, Edit);
base.SetControlAccessable(Edit);
gv_Detail.OptionsBehavior.Editable = Edit; }

完成以后运行重新加载模块,测试功能

添加商品到此完结

关于GZFramwork快速开发框架

作者:GarsonZhang  QQ:382237285

唯一QQ交流群:288706356

欢迎提出您的宝贵意见

GZFramwork快速开发框架演练之会员系统(四)添加商品管理的更多相关文章

  1. GZFramwork快速开发框架演练之会员系统(三)添加会员等级管理

    1.设计会员等级表结构 创建语句: from sysobjects where id = object_id('tb_MembersLevel') and type = 'U') drop table ...

  2. GZFramwork快速开发框架演练之会员系统(二)添加字典模块

    开始前请先阅读 GZFramwork快速开发框架之窗体设计说明 第一步:准备模块图片 图片为2张大小分别为16x16和32x32,放在\Debug\images目录下    因为会员管理模块并不多   ...

  3. GZFramwork快速开发框架演练之会员系统(一)框架源码下载

    GZFramwork框架开发环境为.NET 4.0 (必须)   VS2013+SQL2005+DevExpress v13.2.8+FastReport (推荐)  数据库建模工具PowerDesi ...

  4. GZFramwork快速开发框架之窗体设计说明

    1.  明细页数据源获取(基类已经处理) 重载GetEditData方法,此方法为自定义获得明细也的数据源,用于绑定明细页,此返回值会赋值给EditData //根据主键获得数据编辑页的数据 publ ...

  5. ASP.NET快速开发框架、这才是高大上档次后台管理UI界面

    另外献上在<线体验Demo地址>希望大家也能从中得到一些启发.地址:http://121.40.148.178:8080/ . 用户名:guest,密码:123456QQ技术交流群:239 ...

  6. ASP.NET通用权限系统快速开发框架

    系统在线演示地址: http://120.90.2.126:8051 登录账户:system,密码:system### DEMO下载地址: http://download.csdn.net/detai ...

  7. C# 嵌入dll 动软代码生成器基础使用 系统缓存全解析 .NET开发中的事务处理大比拼 C#之数据类型学习 【基于EF Core的Code First模式的DotNetCore快速开发框架】完成对DB First代码生成的支持 基于EF Core的Code First模式的DotNetCore快速开发框架 【懒人有道】在asp.net core中实现程序集注入

    C# 嵌入dll   在很多时候我们在生成C#exe文件时,如果在工程里调用了dll文件时,那么如果不加以处理的话在生成的exe文件运行时需要连同这个dll一起转移,相比于一个单独干净的exe,这种形 ...

  8. CRL快速开发框架系列教程四(删除数据)

    本系列目录 CRL快速开发框架系列教程一(Code First数据表不需再关心) CRL快速开发框架系列教程二(基于Lambda表达式查询) CRL快速开发框架系列教程三(更新数据) CRL快速开发框 ...

  9. 力软信息化系统快速开发框架 web端+winform端

    力软信息化系统快速开发框架是一套集权限管理+快速开发+动态接口+通用组件+动态UI于一体的全新.net信息化快速开发框架.力软信息化系统快速开发框架的使用,大大地缩短了开发周期,提高了软件质量,同时也 ...

随机推荐

  1. js循环的总结

    js原生的循环有两种,一般的for循环和for...in循环.还有一种常用jQuery.each()循环. 一. js原生循环 a. for循环,代码如下: var myArray = [1,2,3] ...

  2. cookbook学习第二弹

    1.5怎样实现一个按优先级排序的队列?并且在这个队列上面每次pop操作总是返回优先级最高的那个元素 带有双下划线的方法,会在需要被调用的位置自动被调用 带有单下划线的变量是私有变量 下面利用类heap ...

  3. angular 路由去除#号

    1.  路由启动          $locationProvider.html5Mode(true);  通过pushstatex修改url app.js define([ 'angular', & ...

  4. CAShapeLayer(持续更新)

    CAShapeLayer 之前讲过CALayer动画相关知识,再来看看更加复杂的CAShapeLayer相关的动画知识. 普通CALayer在被初始化时是需要给一个frame值的,这个frame值一般 ...

  5. vi/vim

    config file location 1. MinGW: C:\MinGW\msys\1.0\share\vim\vimrc 2. Linux: home config file content ...

  6. javascript源代码学习之五——jQuery.deferred

    jQuery.Defered——异步队列用于管理一组回调函数(成功resolve,失败reject,消息progress),基于上一节实现的jQuery.callbacks完成. done,fail, ...

  7. 简要介绍Apache、php、mysql安装和工具介绍

    1 安装Apache 网站:www.Apache.org下载相应的Apache,目前下载了近期的:httpd-2.2.15-win32-x86-openssl-0.9.8msi 安装简要步骤如下图: ...

  8. Leetcode: Nested List Weight Sum II

    Given a nested list of integers, return the sum of all integers in the list weighted by their depth. ...

  9. c++ socket编程步骤

    sockets(套接字)编程有三种,流式套接字(SOCK_STREAM),数据报套接字(SOCK_DGRAM),原始套接字(SOCK_RAW):基于TCP的socket编程是采用的流式套接字. 服务器 ...

  10. windows系统调用 临界区机制

    #include "iostream" #include "windows.h" #include "cstring" using name ...