| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 3246 人关注过本帖
标题:关于列表框和组合框的displayvalue和value属性
取消只看楼主 加入收藏
mary5610
Rank: 1
等 级:新手上路
帖 子:51
专家分:0
注 册:2016-4-27
结帖率:64.29%
收藏
已结贴  问题点数:14 回复次数:2 
关于列表框和组合框的displayvalue和value属性
据我的认识,displayvalue属性是当前值,value属性是取当前对象的序列值(1,2,……),那为什么实际操作中,二者没发现区别呢?例如在combo的interactivechange事件中:
    aver 基本工资 to gz for alltr(this.displayvalue)=allt(部门)
    thisform.text1.value=gz
红色部分替换为value结果不变,如果是数字的话怎么也能统计到呢?
搜索更多相关主题的帖子: 统计 
2016-05-23 13:09
mary5610
Rank: 1
等 级:新手上路
帖 子:51
专家分:0
注 册:2016-4-27
收藏
得分:0 
以下是引用mywisdom88在2016-5-23 18:07:18的发言:

1、Combo1.init
this.AddItem("你好")
this.AddItem("我好")
this.AddItem("他好")
this.Value=1
*此时,不管你选择的是什么,Value 是序号,DisplayValue是选择的,如选择“我好”,那 Value=2,DisplayValue="我好"
*如果是输入,DisplayValue="输入的",Value=0
2、Combo2.init
this.AddItem("你好")
this.AddItem("我好")
this.AddItem("他好")
this.Value="你好"
*此时,不管你选择的是什么,Value=DisplayValue="选择的"
*如果是输入,DisplayValue="输入的",Value=""
 
3、Combo3.init
CREATE CURSOR tmp(id int ,name c(8))
FOR i=1 TO 5
INSERT INTO tmp(id,name) values(i,'张三'+TRANSFORM(i))
ENDFOR
 
WITH
    .COLUMNCOUNT=2
    .BoundColumn =2
    .COLUMNWIDTHS="80,60"
    .ROWSOURCE="tmp"
    .ROWSOURCETYPE=2
    .DISPLAYVALUE=""
    .REQUERY
ENDWITH
*Value 和BoundColumn 有关,DisplayValue 的值是选择的值
*如果是输入的,DisplayValue=“输入的",Value=""
也就是说,当combo的数据源只有一列时,displayvalue和value是没有区别的,可以这样理解吗?
当有多列时,displayvalue时选定项目第一列的值,而value则是选定项目绑定列(boundcolumn可能是1也可能不是1)的值.
2016-05-23 20:10
mary5610
Rank: 1
等 级:新手上路
帖 子:51
专家分:0
注 册:2016-4-27
收藏
得分:0 
以下是引用mywisdom88在2016-5-24 08:52:49的发言:

可以这样说,value和他的初始化有关。
1、Combo1.init  
this.Value=1  
*初始化为数值,即this.Value=1
*选择:value=序号;displayvalue=选择值;不相同
*输入:value=0;displayvalue=输入值;不相同
 
2、Combo2.init  
this.Value=""  
*初始化为字符,即this.Value=""
*选择:value=选择值;displayvalue=选择值;相同
*输入:value="";displayvalue=输入值;不相同
 
3、Combo3.init  
CREATE CURSOR tmp(id int ,name c(8))  
FOR i=1 TO 5  
INSERT INTO tmp(id,name) values(i,'张三'+TRANSFORM(i))  
ENDFOR  
  
WITH   
    .COLUMNCOUNT=2  
    .BoundColumn =2 && value的值绑定为第2列
    .COLUMNWIDTHS="80,60"  
    .ROWSOURCE="tmp"  
    .ROWSOURCETYPE=2  
    .DISPLAYVALUE=""  
    .REQUERY  
ENDWITH  
*上面没初始化value,默认就是字符,
*选择:value和 BoundColumn 的值有关,displayvalue=选择值,也就是第1列
*输入:value="";displayvalue=输入值
*如果初始化 value=1
*选择:value和 BoundColumn 没什么关,为序号,displayvalue=选择值,也就是第1列
*输入:value=0;displayvalue=输入值
*这里说的输入,都是指列表中原先没有的,新增加输入的。
OK,谢谢。
2016-05-24 09:52
快速回复:关于列表框和组合框的displayvalue和value属性
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.020012 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved