二开--老单单据插件开发案例一原创
金蝶云社区-Robby
Robby
15人赞赏了该文章 1,206次浏览 未经作者许可,禁止转载编辑于2023年02月13日 15:06:37
summary-icon摘要由AI智能服务提供

本文案例讲述了在ERP系统中,如何在采购订单单据上添加自定义字段以记录物料规格型号,并确保修改基础资料时该字段不变。步骤包括:1)在单据自定义工具中添加分录字段;2)注册单据插件;3)进行代码开发,实现字段值的自动填充和事件处理;4)编译工程并注册组件。文中还详细说明了代码开发和调试的注意事项。

案例:采购订单增加字段记录物料录单时的规格型号,保存后基础资料修改了规格型号也不会改变单据上的这个字段。

1.单据自定义工具中添加一个分录字段,定义为手工录入的:
image.png

保存模板后台查到自己添加到的字段的关键字

select * from ICTransactionType where FName ='采购订单' --查出来FID71,TemplateIDP02

select * from ICTemplateEntry where FID = 'P02' 查看表体模板FFieldName

物料字段是FitemID,规则型号是FItemModel,自定义字段是FEntrySelfP0272

2.注册单据插件:

insert into t_ThirdPartyComponent(FTypeID,FTypeDetailID,FIndex,FComponentName) values(0,71,1,'UserBillPrj.CBill71')

Go

FTypeID :0 表示客户端单据插件

FTypeDetailID:71 单据类型

FIndex:顺序,随意填不要和本单据类型已存在的插件重复,一个单据存在多个插件时,是从小到大依次执行;

FComponentName:UserBillPrj.CBill71是自己开发的vb组件类 【组件名称.类名】

image.png

3.代码开发:

工程需要引用一下几个动态库k3billtransfer(必须),

kingdee foundation object 1.0,如果要用到kfo.dictionary对象

jxc function v2.0\microsoft activex dataobject 2.x library 如果用到数据库交互

image.png

一:注册插件事件对象m_billtransfer.单据插件必须显示实现Show方法:

image.png

代码解析:m_lngtranstype = xxx 这段是获取当前单据的类型,

所有单据插件中都必须区分单据类型,避免不同类型单据公用插件时执行业务逻辑交叉了。

再Show的过程中先把需要用到的字段位置号查出来,show方法只会再单据界面打开时加载一次;

image.png

实现插件的表体值更新事件:GridChange

当前需求要把录入物料之后默认的规格型号字段的数据填到自定义字段上去:

strModel = m_billtransfter.GetGridText(Row,lngModelPlace)获取界面上规格型号字段

设置到自定义的字段上

m_billtransfter.setGridText row,lngUserFieldPlace,strModel

截图中该函数后半段代码是演示sql交互的代码,与实际需求无关:

要获取单据表体某个核算项目字段的内码需要用DInterID(Row)来取,用GetGridText只能提取到当前界面的文本值,有可能是编码或者是名称;

sql交互,直接使用ExecuteSql函数即可;


备注:如果代码中存在sql交互则不能直接调试(因为二开时没有kdmain工程代码,会导致调试时sql交互的时候连接串异常),可以使用写日志到本地文本或者直接msgbox抛出来,来跟踪代码;


编译工程,将组件放到k3erp目录下,然后用regsvr32命令注册;


图标赞 15
15人点赞
还没有人点赞,快来当第一个点赞的人吧!
图标打赏
0人打赏
还没有人打赏,快来当第一个打赏的人吧!