实习日志day8---任务一总结

这篇博客记录了作者在实习期间参与的一个大型项目,主要涉及库存界面的开发和数据库交互。项目采用MVC模式,使用了MPDEC、ESMASTMAIN等库。作者详细介绍了新建界面、数据绑定、搜索功能、行点击事件的实现,并分享了在数据库操作和代码调试中遇到的挑战。最后,作者强调了亲自思考和编写代码对于项目理解的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这算是我目前为止参与的最大的项目了。模块名和项目结构命名都是规范的,可以知道各个模块大概用途。

简单介绍项目的组成和使用的库:

MPDEC :现成的库,解决数据库中浮点型数问题,

ESMASTMAIN:解决方案主入口,

master:动态链接库,编写。

使用MVC模式,m--数据处理逻辑 v--跟用户交互的视图 c---流程控制,数理逻辑控制

comm:基础类库,html头文件,引用 静态库。

baslib:基础库,http请求,封装的库,跟数据库打交道的。

界面布局 --view,模块。

soci:c++跟数据库打交道的现成的库 mysql

htmllayout:界面引擎,渲染html,css

 

任务一是写库存界面并完成相应功能,功能及主要实现介绍:

1.新建界面:

在view下建html文件,在controller中添加类文件,在main.html中注册窗体,添加节点。

.h文件中:                         

DESCRIBE_WINDOW_EX(CDemoWindow_yxm, //创建窗体
L"practice/task1/demo_yxm.html", //需要的html的位置
900, 
600, 
_T("叶雪梅_分仓库"),
WS_VISIBLE|WS_CLIPCHILDREN|WS_CHILD, 
0,
TRUE,
TRUE,
TRUE);

.cpp文件中:

REGISTER_WINDOW(CDemoWindow_yxm, "DemoWindow_yxm"); //注册窗体,类名,窗体名(在main中target指定)。

 

2.从数据库中获取数据并显示在列表:

定义onload函数:使用dom元素的xcall方法。在cpp中实现的函数,都需要到h文件中声明。sql文件需要包含在SqlDict文件中。

void Task1Window_yxm::OnLoad(LPVOID lpPrams) //页面加载
{
dom::element elGoodsList=this->find_first("#goods_list"); //从当前窗体中找到元素
elGoodsList.xcall("page_bind","task1_goods_list",c_WareHouseID); //数据绑定,执行sql4  
return;
}

 

3.搜索:

获得文本框的值,判断搜索方式,使用sql文件中不同的查询语句,即可搜索并显示。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
c_WareHouseID=GetValue("#warehouse_list",0);
    int nType=GetValue("#sel_search_type",0);
    std::wstring wsKey=GetValue("#search_item",L"");//获取文本框的值
 
    //wsKey=StrUtils::EscapeSQL(wsKey.c_str(),true);  //防止sql注入,命名空间--字符串相关
 
    dom::element elGoodsList=this->find_first("#goods_list");
 
    switch(nType)
    {
    case 1:  //按编号搜索
        {
             
            elGoodsList.xcall("page_bind","goods_list_byNo",c_WareHouseID,wsKey);
            break;
        };
    case 2:  //按名称搜索
        {
             
            wsKey = L"%"+wsKey+L"%";
            elGoodsList.xcall("page_bind","goods_list_byname",c_WareHouseID,wsKey); //将wsKey替换到sql中的GoodsName,占位符
            break;
        };
    case 3:  //显示全部
        {
            elGoodsList.xcall("page_bind","task1_goods_list",c_WareHouseID);
            break;<br>}

  

4.行点击事件:

//listview行点击事件
BOOL Task1Window_yxm::OnClickGoodsItem(HELEMENT he,BEHAVIOR_EVENT_PARAMS & params) //句柄,消息参数
{
dom::element elRow=BEHAVIOR_TARGET(params); //获得当前选中的行
//std::string str=elRow.get_html().c_str();
int nGoodsID=elRow.get_attribute_int("data-GoodsID",0); //取出选中行的goodID,0为缺省值
dom::element elSpecList=this->find_first("#spec_list");
elSpecList.xcall("bind","task1_spec_list_byid",nGoodsID);//不分页,将查询到的数据绑定到界面,nGoodsID用于替代sql语句缺省值
return true;
}

 

5.新建和修改也是类似的,主要就是soci库的使用,和方法的组合调用。开始时会觉得陌生,熟悉后就会好很多。

做起来很慢的原因有:mysql语句很不熟,soci使用问题重重,vs调试问题,在调试上花了很多时间,需要更熟悉项目,写代码前先把思路理清楚,也更需要细心。

数据库这块正好利用这三个任务好好练习。

 

6.右击菜单,盘点:

这个几乎都是使用现成项目的代码,功能还需要完善,主要是sql语句的问题。

因为直接copy的,所以细节自己并不清楚,思维停滞,导致做的没意思。做项目结果固然重要,但那个过程才是自己的。应该自己敲的代码,应该做的过程都是需要自己去做的,这样思维才会活跃,才能更好的掌握项目,正真的有所收获。所以,自己去思考设计,自己去写每一行代码,知道每一行代码存在的理由,你亲自想出来,亲自敲出来的代码,是你赋予的生命。

这个任务做了5天,先是看视频,然后看别人的源码作参考,才慢慢上手,数据库真的需要好好补补。做的不快,但自己写的那个过程很有干劲和感觉,最后一个功能,为了偷懒和进度,是最没有感觉的。自己思考和做的过程对自己是最有价值的。


2016.7.22

北京 掌上先机

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值