Rss & SiteMap

Foxtable(狐表) http://www.foxtable.com

新一代数据库软件,完美融合Access、Foxpro、Excel、vb.net之优势,人人都能掌握的快速软件开发工具!
共10 条记录, 每页显示 10 条, 页签: [1]
[浏览完整版]

标题:请教保存好以后不允许编辑的问题

1楼
LCQQLJ 发表于:2012/1/6 12:27:00

再请教你一个问题行吗,我想在销售单价列编辑好以后,不是马上不允许编辑,而是保存好以后不允许编辑,怎么设计?


2楼
don 发表于:2012/1/6 13:02:00

让不同用户编辑不同的列

假定一个表,要求:

1、禁止张三和李四编辑第一列、第二列和第三列。
2、禁止王五和赵六编辑第四列、第五列和第六列。
3、只有张经理编辑才能编辑第十列。

为此可将此表的PrepareEdit事件代码设置为:

Select Case User.Name
    Case
"张三",
"李四"
       
Select Case e.Col.Name
            Case
"第一列","第二列","第三列"

                e.Cancel =
True
       
End Select
   
Case "王五", "赵六"
       
Select Case e.Col.Name
            Case
"第四列","第五列","第六列"

                e.Cancel =
True
       
End Select
End
Select
If
e.Col.Name = "第十列" Then
    If User.Name <> "张经理" Then
        e.Cancel =
True
   
End If
End
If

实际应用的时候,将上述代码替换为具体的列名和用户名即可。

上面的代码是基于用户名的,同样可以改为基于用户分组的,只需将上述代码中的User.Name改为User.Group,并将用户名替换为分组名即可。

3楼
LCQQLJ 发表于:2012/1/6 14:23:00

谢谢指教

4楼
LCQQLJ 发表于:2012/1/6 14:27:00
这种办法编辑好以后马上就不能重新修改,也不方便,我想只有保存文件以后再禁止修改,要修改只能由部分人进行。
5楼
狐狸爸爸 发表于:2012/1/6 14:57:00

在PrePareEdit事件中判断行的状态,如果不是新增行,就只允许某些人编辑。

http://www.foxtable.com/help/topics/0605.htm

http://www.foxtable.com/help/topics/0428.htm

 

 

6楼
LCQQLJ 发表于:2012/1/6 15:05:00
谢谢狐狸爸爸,我是新手中的新手,你指教的方法,我慢慢理解、学习,谢谢!
7楼
狐狸爸爸 发表于:2012/1/6 15:10:00

例如将prepareedit事件代码设置为:

 

If e.Row.DataRow.RowState <> DataRowState.Added Then
    e.cancel = True
End If

 

就只允许编辑新增加的行,无法编辑已经保存的行。

8楼
LCQQLJ 发表于:2012/1/6 15:14:00

太感谢你了

 

9楼
LCQQLJ 发表于:2012/1/6 15:15:00

太感谢你了

10楼
LCQQLJ 发表于:2012/1/6 15:47:00
狐爸:哪如果让上级权限的人进行修改的话,再怎么往下编译呢?
共10 条记录, 每页显示 10 条, 页签: [1]

Copyright © 2000 - 2018 foxtable.com Tel: 4000-810-820 粤ICP备11091905号

Powered By Dvbbs Version 8.3.0
Processed in .02344 s, 2 queries.