Foxtable(狐表)用户栏目专家坐堂 → [求助]合计代码不执行,请教问题何在?


  共有12663人关注过本帖树形打印复制链接

主题:[求助]合计代码不执行,请教问题何在?

帅哥哟,离线,有人找我吗?
don
  11楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:八尾狐 帖子:1812 积分:12993 威望:0 精华:14 注册:2008/10/11 18:07:00
  发帖心情 Post By:2011/8/15 21:28:00 [只看该作者]

Select Case e.DataCol.Name
    Case "数量","剂量","单价" 
           Dim n1,n2  as Double     
            n1 = e.DataRow("剂量")
            n2 = e.DataRow("数量")
            e.DataRow("合计") = iif(n1<> 0,n1,n2) * e.DataRow("单价")        
End Select

 回到顶部
帅哥哟,离线,有人找我吗?
yanzhen2010
  12楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:童狐 帖子:212 积分:1564 威望:0 精华:0 注册:2011/7/20 21:00:00
  发帖心情 Post By:2011/8/15 23:08:00 [只看该作者]

谢谢老总和朋友的不吝赐教和帮助,代码都正确。
这是我自己写的代码,也能用。
Select Case e.DataCol.Name
    Case "数量","单价"
        If e.DataRow("数量") IsNot Nothing Then
            e.DataRow("合计") = e.DataRow("数量") * e.DataRow("单价")
        End If
    Case "剂量","单价"
        If e.DataRow("剂量") IsNot Nothing Then          
            e.DataRow("合计") = e.DataRow("剂量") * e.DataRow("单价")
        End If
End Select

 回到顶部
帅哥哟,离线,有人找我吗?
狐狸爸爸
  13楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:管理员 帖子:47448 积分:251060 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2011/8/15 23:12:00 [只看该作者]

下面的代码是不对的:

 

 If e.DataRow("数量") IsNot Nothing Then

 

判断是否为空,只能用isnull,你结果正确只是凑巧。


 回到顶部
帅哥哟,离线,有人找我吗?
yanzhen2010
  14楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:童狐 帖子:212 积分:1564 威望:0 精华:0 注册:2011/7/20 21:00:00
  发帖心情 Post By:2011/8/15 23:14:00 [只看该作者]

但是问题之解决了第一步,第二个问题是:
如果"数量"不等于空值,那么"剂量"禁止输入内容。
反之"剂量"不等于空值,那么"数量"禁止输入内容。
也就是"数量"和"剂量"列只允许其中之一列允许编辑,只要一列已经存在内容,另一列处于禁止编辑状态。

 回到顶部
帅哥哟,离线,有人找我吗?
狐狸爸爸
  15楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:管理员 帖子:47448 积分:251060 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2011/8/15 23:28:00 [只看该作者]

这个表,第一列和第二列,只能有一列输入数据: 

 

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:管理项目10.rar


 回到顶部
总数 15 上一页 1 2