pb 如何判断数据窗口中是否有某个字段_PB 数据窗口中限定某列不可编辑

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

问题的提出

在进行PowerBuilder应用系统开发过程中,对于某些数据录入窗

口,我们希望将某列置为不可编辑的,防止用户由于操作不慎而删掉数

据。下面介绍如何实现这一功能。

在PowerBuilder的DataWindow里,如果设定Grid风格,那么这个Da

taWindows就具有这样一个特点:当用鼠标点列名后,即可选中整列(该

列反显成黑色)。这就为我们解决问题提供了一些思路:用鼠标点中某

列,使该列变成不可编辑。

二、解决办法

方法一:

在DataWindow中,列与列之间用Tab键进行移动时,是依据DataWin

dow为每一列设置的Tb 值来进行移动的。当某列的Tab值为0时,此列

不可编辑,使用户无法对其进行增、删、改等操作。故可将某列的Tab

值置为0,即可让此列设为不可编辑。

方法如下(设columnname为DataWindow中要置成的不可编辑的列

名):

dw_1.setorder("columnname",0)

或者在数据窗口的script中用以下语句进行修改:

dw_1.modify(:columnname.tabsequence=0")

或dw_1.modify("#"+string(number)+".tabsequence=0")

该方法的优点是易于实现,缺点是不允许列进行移动。即在Grid

风格的DataWindow中,必须不选中column moving,否则按下tab键时会

引起顺序混乱。

方法二:

可查看列属性中的edit属性,查看style风格。若要将某列置不可

编辑,可在该列的edi style="edit"中选中display only;或者在窗口

的script中用以下语句进行修改:

dw+1.modify("columnname.edit. displayonly=Yes)

或dw_1.modify("#"+string(number)+".edit.displayonly=Yes"

)

若将该列改回可编辑,可在该列的edit style="edit"中,不选中d

isplay only;或者在窗口的script中用以下语句进行修改:

dw_1.modify("columnname.edit.displayonly=No")

该方法也很简单,但同样不允许列移动。

方法三:

用DataWindow的clicked事件中的方法也可以实现列的保护。若

某列不可更改,则可置r otect=0。即:

dw_1.modify("columnname.protect=0")

或dw_1.modify("#"+string(number)+".protect=0")

若要将该列改为可更改,则置protect=1,即:

dw_1.modify(:columnname.protect=1")

或dw_1.modify("#"+string(number)+".protect=1")

此方法不影响Tab键的移动,用户可以随意拉动列,还可在应用过

程中自己决定哪一列可编辑,哪一列不可编辑。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值