| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 3247 人关注过本帖
标题:关于列表框和组合框的displayvalue和value属性
只看楼主 加入收藏
mary5610
Rank: 1
等 级:新手上路
帖 子:51
专家分:0
注 册:2016-4-27
结帖率:64.29%
收藏
已结贴  问题点数:14 回复次数:9 
关于列表框和组合框的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
tlliqi
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:204
帖 子:15453
专家分:65956
注 册:2006-4-27
收藏
得分:3 
没发现区别
2016-05-23 14:11
mywisdom88
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:191
帖 子:3147
专家分:8408
注 册:2015-3-25
收藏
得分:3 
如果COMBO的值是用 THIS.ADDITEM("天") 的,THIS.VALUE 就是序号
如果是用数据源的,displayvalue的值和 BOUNDCOLUMN与 columnCount 的设置有关系
如果BOUNDCOLUMN=1,columnCount=0

displayvalue的值,基本上等于 value,条件是,2者都有效的时候。
2016-05-23 14:52
sdta
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:江苏省连云港市
等 级:版主
威 望:335
帖 子:9841
专家分:27213
注 册:2012-2-5
收藏
得分:3 
我的理解是,DISPLAYVALUE 是在控件选择过程中使用的值,VALUE是在控件显示时使用的值。
THISFORM.LIST1.VALUE=THISFORM.LIST1.DISPLAYVALUE

[此贴子已经被作者于2016-5-23 15:37编辑过]


坚守VFP最后的阵地
2016-05-23 15:34
吹水佬
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:451
帖 子:10607
专家分:43186
注 册:2014-5-20
收藏
得分:3 
好象是这样,没测试。
选定时:
DisplayValue 第1列值,Value 是第 BoundColumn 列的值。
编辑时:
如果列表中存在,Value=DisplayValue=输入的值。如果列表中不存在,Value=空,DisplayValue=输入的值。
2016-05-23 16:03
mywisdom88
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:191
帖 子:3147
专家分:8408
注 册:2015-3-25
收藏
得分:0 
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=""
2016-05-23 18:07
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
hu9jj
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:红土地
等 级:贵宾
威 望:400
帖 子:11857
专家分:43421
注 册:2006-5-13
收藏
得分:3 
以下是引用mary5610在2016-5-23 20:10:21的发言:

也就是说,当combo的数据源只有一列时,displayvalue和value是没有区别的,可以这样理解吗?

我的理解:value有可能是序号,与displayvalue有时会不一致。

活到老,学到老!http://www.(该域名已经被ISP盗卖了)E-mail:hu-jj@
2016-05-24 07:58
mywisdom88
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:191
帖 子:3147
专家分:8408
注 册:2015-3-25
收藏
得分:0 
可以这样说,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=输入值
*这里说的输入,都是指列表中原先没有的,新增加输入的。

[此贴子已经被作者于2016-5-24 08:57编辑过]

2016-05-24 08:52
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.032330 second(s), 10 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved