标签:该行 Sender AKeyValue cxGrid TForm1 var AItem 锁定 TcxCustomGridTableView
在使用cxGrid时,由于设置了所有单元格都能编辑,
但在特定的情况下,让某些行,根据一些列值条件,让该行整行锁定,不能编辑。
研究了很久,在DevExpress官网上找到了相关的资料,因此,分享给大家。
Dev官网的列子是这样的
// DISABLE A ROW 整行禁止编辑
procedure TForm1.cxGrid1DBTableView1Editing(Sender: TcxCustomGridTableView;
AItem: TcxCustomGridTableItem; var AAllow: Boolean);
var
AKeyValue : Variant;
begin
AKeyValue := Sender.DataController.GetRecordId(Sender.Controller.FocusedRecordIndex);
if (AKeyValue = '1351') or (AKeyValue = '1356') or (AKeyValue = '1384') then
AAllow := False;
end;
// MAKING A ROW READ ONLY 让一行只读
procedure TForm1.cxGrid1DBTableView1InitEdit(
Sender: TcxCustomGridTableView; AItem: TcxCustomGridTableItem;
AEdit: TcxCustomEdit);
var
AKeyValue : Variant;
begin
{ AKeyValue := Sender.DataController.GetRecordId(Sender.Controller.FocusedRecordIndex);
if (AKeyValue = '1351') or (AKeyValue = '1356') or (AKeyValue = '1384') then
AEdit.ActiveProperties.ReadOnly := True;}
end;
// MAKING A ROW LOOK LIKE DISABLED 让一行看起来禁止了
procedure TForm1.cxGrid1DBTableView1StylesGetContentStyle(
Sender: TcxCustomGridTableView; ARecord: TcxCustomGridRecord;
AItem: TcxCustomGridTableItem; out AStyle: TcxStyle);
var
AKeyValue : Variant;
begin
AKeyValue := Sender.DataController.GetRecordId(ARecord.RecordIndex);
if (AKeyValue = '1351') or (AKeyValue = '1356') or (AKeyValue = '1384') then
AStyle := cxDisableStyle;
end;
在实际使用中,若要根据某列的值,控制该行是否可编辑,代码如下:
procedure TForm1.cxGrid1DBTableView1Editing(Sender: TcxCustomGridTableView;
AItem: TcxCustomGridTableItem; var AAllow: Boolean);
begin
//cxGrid1DBTableView1CanEdit 为cxGrid中某列,判断不为空时,设置该行不能编辑。
if VarToStrDef(Sender.Controller.FocusedRecord.Values[cxGrid1DBTableView1CanEdit.Index], '') <> '' then
AAllow := False;
end;
本帖为博主原创,转载请注明出处:http://www.cnblogs.com/K-R-/p/6913211.html
谢谢!
标签:该行,Sender,AKeyValue,cxGrid,TForm1,var,AItem,锁定,TcxCustomGridTableView 来源: https://blog.csdn.net/lypingfan/article/details/118764482
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。