ComboBox下拉框汇总

合集下载

Qt样式表(QComboBox下拉框)

Qt样式表(QComboBox下拉框)

Qt样式表(QComboBox下拉框)/* 未下拉时,QComboBox的样式 */QComboBox {border: 1px solid gray; /* 边框 */border-radius: 3px; /* 圆⾓ */padding: 1px 18px 1px 3px; /* 字体填衬 */color: #000;font: normal normal 15px "Microsoft YaHei";background: transparent;}/* 下拉后,整个下拉窗体样式 */QComboBox QAbstractItemView {outline: 0px solid gray; /* 选定项的虚框 */border: 1px solid yellow; /* 整个下拉窗体的边框 */color: green;background-color: red; /* 整个下拉窗体的背景⾊ */selection-background-color: lightgreen; /* 整个下拉窗体被选中项的背景⾊ */}/* 下拉后,整个下拉窗体每项的样式 */QComboBox QAbstractItemView::item {height: 50px; /* 项的⾼度(设置pComboBox->setView(new QListView());后,该项才起作⽤) */}/* 下拉后,整个下拉窗体越过每项的样式 */QComboBox QAbstractItemView::item:hover {color: #FFFFFF;background-color: lightgreen; /* 整个下拉窗体越过每项的背景⾊ */}/* 下拉后,整个下拉窗体被选择的每项的样式 */QComboBox QAbstractItemView::item:selected {color: #FFFFFF;background-color: lightgreen;}/* QComboBox中的垂直滚动条 */QComboBox QAbstractScrollArea QScrollBar:vertical {width: 10px;background-color: #d0d2d4; /* 空⽩区域的背景⾊*/}QComboBox QAbstractScrollArea QScrollBar::handle:vertical {border-radius: 5px; /* 圆⾓ */background: rgb(160,160,160); /* ⼩⽅块的背景⾊深灰lightblue */}QComboBox QAbstractScrollArea QScrollBar::handle:vertical:hover {background: rgb(90, 91, 93); /* 越过⼩⽅块的背景⾊yellow */}/* 设置为可编辑(setEditable(true))editable时,编辑区域的样式 */QComboBox:editable {background: green;}/* 设置为⾮编辑(setEditable(false))!editable时,整个QComboBox的样式 */QComboBox:!editable {background: blue;}/* 设置为可编辑editable时,点击整个QComboBox的样式 */QComboBox:editable:on {background: green;}/* 设置为⾮编辑!editable时,点击整个QComboBox的样式 */QComboBox:!editable:on {background: blue;}/* 设置为可编辑editable时,下拉框的样式 */QComboBox::drop-down:editable {background: lightblue;}/* 设置为可编辑editable时,点击下拉框的样式 */QComboBox::drop-down:editable:on {background: lightgreen;}/* 设置为⾮编辑!editable时,下拉框的样式 */QComboBox::drop-down:!editable {background: lightblue;}/* 设置为⾮编辑!editable时,点击下拉框的样式 */QComboBox::drop-down:!editable:on {background: lightgreen;}/* 点击QComboBox */QComboBox:on {}/* 下拉框样式 */QComboBox::drop-down {subcontrol-origin: padding; /* ⼦控件在⽗元素中的原点矩形。

Combobox下拉框两级联动

Combobox下拉框两级联动

Combobox下拉框两级联动下拉框的两级联动是我们开发中经常遇到⼀种情况。

⽐如⼀个学⽣管理系统中,根据年级、科⽬及姓名查询学⽣考试成绩,年级和科⽬都是硬盘中的有限数据(数据库)⽽学⽣则可以有⽤户⼿动指定,这时在数据库中有年级和科⽬两张表,每门科⽬都对应⼀个年级,所以我们可以⽤两个下拉框(Combobox)来存储年级和科⽬信息来供⽤户选择。

界⾯如下:这时如果我们将科⽬对应的下拉框直接绑定科⽬表时,⽤户选择⼀个年级后还要从所有科⽬中进⾏选择就会降低系统的友好性,甚⾄可能出现没有任何意义的查询语句。

我们可以先绑定年级下拉框的数据。

在年级下拉框中的SelectedIndexChange事件中获取年级下拉框中的数据(编号)在⽤得到的数据(年级编号)去查科⽬表,将对应的科⽬信息绑定到科⽬下拉框。

model展开1 int gradeid = Convert.ToInt32(cboGrade.SelectedValue);//获取选定的年级编号 2 3 List list= subjectBll.GetAllSubject(gradeid);//查询指定年继编号下对应的科⽬信息 4 //绑定科⽬下拉框 5 cboSubject.ValueMember = "subjectid"; 6 cboS 返回顶部收缩 1 int gradeid = Convert.ToInt32(cboGrade.SelectedValue);//获取选定的年级编号23 List <Subject> list= subjectBll.GetAllSubject(gradeid);//查询指定年继编号下对应的科⽬信息4 //绑定科⽬下拉框5 cboSubject.ValueMember = "subjectid";6 cboSubject.DisplayMember = "subjectname";7 cboSubject.DataSource = list;下拉框的SelectedValue属性属性原型:常见错误:错误分析:经过实验可以确认将绑定数据源的代码放在属性设置的后边是可以解决这个错误的,个⼈觉得是如果先绑定数据源的话系统会⾃动将valuemember的属性值设置为绑定的集合的类型之后再设置Valuemember时系统不会再对其进⾏更改!。

C#ComboBox下拉显示层次(树)

C#ComboBox下拉显示层次(树)

C#ComboBox下拉显⽰层次(树)数据库中很多时候⽤到树形结构,在界⾯上显⽰时如果是下拉框⼀次性显⽰时需要树结构来体现,看个效果图先:主要是⽤算法补空格,补符号,源码如下:using System;using System.Collections;using System.Collections.Generic;using System.Linq;using System.Windows.Forms;namespace WindowsFormsApplication1 {public partial class Form1 : Form {public Form1() {InitializeComponent();}private List<profile> pList;protected override void OnLoad(EventArgs e) {base.OnLoad(e);pList = new List<profile>();pList.AddRange(new profile[] {new profile { Id = 1, parentId=0, value="A级"},new profile { Id = 2, parentId=0, value="A级"},new profile { Id = 3, parentId=0, value="A级"},new profile { Id = 4, parentId=0, value="A级"},new profile { Id = 5, parentId=0, value="A级"},new profile { Id = 6, parentId=1, value="B级"},new profile { Id = 7, parentId=2, value="B级"},new profile { Id = 8, parentId=2, value="B级"},new profile { Id = 9, parentId=4, value="B级"},new profile { Id = 10, parentId=3, value="B级"},new profile { Id = 11, parentId=7, value="C级"},new profile { Id = 12, parentId=7, value="C级"},new profile { Id = 13, parentId=9, value="C级"},new profile { Id = 14, parentId=9, value="C级"},new profile { Id = 15, parentId=10, value="C级"},new profile { Id = 16, parentId=10, value="C级"},new profile { Id = 17, parentId=13, value="D级"},new profile { Id = 18, parentId=13, value="D级"},new profile { Id = 19, parentId=12, value="D级"},new profile { Id = 20, parentId=17, value="E级"},new profile { Id = 21, parentId=18, value="E级"},new profile { Id = 22, parentId=18, value="E级"},new profile { Id = 23, parentId=21, value="F级"},new profile { Id = 24, parentId=23, value="G级"},new profile { Id = 25, parentId=24, value="H级"},new profile { Id = 26, parentId=12, value="D级"},new profile { Id = 27, parentId=26, value="E级"},new profile { Id = 28, parentId=27, value="F级"},});//实例化⼀个根节点profile rootRoot = new profile();rootRoot.Id = 0;rootRoot.parentId = 0; = "顶级";AppendChildren(pList, rootRoot, 0);List<string> _name = new List<string>();getName(rootRoot, _name);ArrayList list = new ArrayList();for (int i = 0; i < _name.Count; i++) {list.Add(new System.Collections.DictionaryEntry(i, _name[i]));}comboBox1.DataSource = list;comboBox1.DisplayMember = "Value";comboBox1.ValueMember = "Key";//⽤treeView控件显⽰var node = new TreeNode("顶级");this.AddTree(node, 0);this.treeView1.Nodes.Add(node);return;}public void AddTree(TreeNode parentNode, int parentId) {var selectedList = pList.FindAll(item => item.parentId == parentId);foreach (var group in selectedList) {var node = parentNode.Nodes.Add(group.Id.ToString(), group.value);AddTree(node, group.Id);}}private List<int> tag = new List<int>();private void getName(profile p, List<string> name) {//this.listBox1.Items.Add(string.Format("{0}-{1}", p.Id, p.parentId));if (p == null) return;var str = string.Empty;for (var i = 1; i < p.level; i++) {if (tag.Contains(i)) {str += " ";} else {str += "│ ";}}name.Add(string.Format("{0}{1}{2}", str, , p.value, p.parentId, p.Id, p.level)); for (int i = 0; i < tag.Count; i++) {if (tag[i] >= p.level) {tag.Remove(tag[i]);}}if (p.tag == 0) tag.Add(p.level);if (p.profileList != null && p.profileList.Count > 0) {foreach (profile x in p.profileList) {getName(x, name);}}}public void AppendChildren(List<profile> list, profile profile, int count) { try {count++;var id = profile.Id;var subItems = list.Where(ee => ee.parentId == id).ToList();if (subItems.Count > 0) {for (int i = 0; i < subItems.Count; i++) {if (i == subItems.Count - 1) {subItems[i].name = string.Format("{0}{1}", "└--", "");} else {subItems[i].name = string.Format("{0}{1}", "├--", "");}subItems[i].level = count;subItems[i].tag = i == subItems.Count - 1 ? 0 : 1;}profile.profileList = new List<profile>();profile.profileList.AddRange(subItems);}foreach (var subItem in subItems) {AppendChildren(list, subItem, count);}} catch (Exception e) {MessageBox.Show(e.Message);}}}public class profile {public string fill { get; set; }public int tag { get; set; }public string name { get; set; }public int Id { get; set; }public int parentId { get; set; }public string value { get; set; }public int level { get; set; }public List<profile> profileList { get; set; }}。

Qt基础教程之QComboBox下拉框及用法

Qt基础教程之QComboBox下拉框及用法

QComboBox 是下拉列表框组件类,它提供一个下拉列表供用户选择,也可以直接当作一个 QLineEdit 用作输入。

QComboBox 除了显示可见下拉列表外,每个项(item,或称列表项)还可以关联一个 QVariant 类型的变量,用于存储一些不可见数据。

实例演示 QComboBox(和 QPlainTextEdit,后续会讲)的使用,其运行时界面如图 1 所示。

图 1 实例 samp4_6 运行界面QComboBox 的用法设计时属性设置QComboBox 主要的功能是提供一个下拉列表供选择输入。

在界面上放置一个 QComboBox 组件后,双击此组件,可以出现如图 2 所示的对话框,对QComboBox 组件的下拉列表的项进行编辑。

在图 2 所示的对话框中,可以进行编辑,如添加、删除、上移、下移操作,还可以设置项的图标。

图 2 QComboBox 组件设计时的列表项编辑器用代码添加简单项窗口上的“初始化列表”按钮初始化下拉列表框的列表内容,其代码如下:void Widget::on_btnIniItems_clicked(){ //"初始化列表"按键QIcon icon;icon.addFile(":/images/icons/aim.ico");ui->comboBox->clear(); //清除列表for (int i=0;i<20;i++)ui->comboBox->addItem(icon,QString::asprintf("Item %d",i)); //带图标//ui->comboBox->addItem(QString::asprintf("Item %d",i)); //不带图标}添加一个项时可以指定一个图标,图标来源于资源文件。

addItem() 用于添加一个列表项,如果只是添加字符串列表项,而且数据来源于一个 QStringList 变量,可以使用 addltems() 函数,示例代码如下:ui->comboBox->clear();QStringList strList;strList<<"北京"<<"上海"<<"天津"<<"河北省"<<"山东省"<<"山西省";ui->comboBox->addItems(strList);添加具有用户数据的项 QComboBox::addltem() 函数的两种参数的原型定义如下:不管是哪一个 addItem() 函数,后面都有一个可选的 QVariant 类型的参数 userData,可以利用这个变量存储用户定义数据。

ComboBox列表智能自动下拉

ComboBox列表智能自动下拉

namespace WindowsApplication1
{
public partial class Form1 : Form
{
// 构造函数
public Form1()
{
InitializeComponent();
// 构造数据
loaddata();
}
// 构造数据源
private DataTable mdataSource = new DataTable();
// 初始化数据
// 特殊出标志
private bool flag = false;
/// <summary> ቤተ መጻሕፍቲ ባይዱ
/// combobox 输入事件
/// </summary>
/// <param name="sender"></param>
dr5["value"] = "5";
dt.Rows.Add(dr5);
DataRow dr6 = dt.NewRow();
dr6["name"] = "date";
dr6["value"] = "6";
ComboBox列表智能自动下拉
实际操作步骤和思路如下:
1、在text_changed里触发
2、在比对后要进行加载将要显示相关数据(如动态数据绑定等),向下拉列表添加内容: comboBox1.Items.Add(str); 使用此语句可以添加str到下拉列表中
3、最后,设置 comboBox1.DroppedDown = true; 可以显示下拉列表的内容。

jQueryEasyUI-ComboBox(下拉列表框)

jQueryEasyUI-ComboBox(下拉列表框)

jQueryEasyUI-ComboBox(下拉列表框)⼀、combobox 前台页⾯动态加载显⽰判断输⼊值在下拉列表是否存在var nameStr ='';$(document).ready(function(){$('#customerId').combobox({prompt:'请输⼊或选择客户名称', //prompt属性为没有选中任何选项的时候显⽰的标签如“--性别--”url:'${rc.contextPath}/sale/findBusinessPartnerByName',valueField:'id',textField:'text' ,onClick: function(node) {attributeShow($("#customerId").combotree("getValue"));},filter: function(q, row){ //filter属性模糊查询var opts = $(this).combobox('options');//return row[opts.textField].indexOf(q) == 0;return row[opts.textField].indexOf(q)>-1;//将从头位置匹配改为任意匹配},onLoadSuccess: function(){var partnerId = '${(saleOrder.partnerId)!}';if(partnerId){$('#customerId').combobox('setValue',partnerId);}},onSelect: function(){var partnerId = $("#customerId").combotree("getValue");$("#business_partner_id").val(partnerId);findBusinessPartnerContactByPartnerId(partnerId);findSaleAddressByPartnerId(partnerId);},onChange: function(newValue, oldValue){var v = $("#customerId").combotree("getText");var arr = nameStr.split(',');var index = $.inArray(v, arr);if(index < 0 ){$("#business_partner_id").val('');}else{$("#business_partner_id").val($("#customerId").combobox("getValue"));}},formatter: function(row){var opts = $(this).combobox('options');nameStr += row[opts.textField] + "," ;return row[opts.textField];}});});Combobox⽤法和⽅法参数:1、需要引⼊class=" easyui-combobox”2、参数设置需要在data-options中设置3、属性参数配置:valueField:基础数据值名称绑定到Combobox(提交值)textField:基础数据的字段名称绑定的Combobox(显⽰值)mode:定义当⽂本改变时如何加载列表数据,当设置为remote模式下,什么类型的⽤户将被发送http请求参数名为'q'的服务器,以获取新的数据。

C#WinformComboBox在输入内容时会在下拉菜单中显示根据输入内容查询的结果

C#WinformComboBox在输入内容时会在下拉菜单中显示根据输入内容查询的结果

C# Winform ComboBox 在输入内容时 会在下拉菜单中显示根据输入内容查询的结果将 ComboBox 的 AutoCompleteMode 属性置为SuggestAppend , AutoCompleteSource 属性置为 ListItems ,然 后给 ComboBox 随便塞几个子项,运行看效果。

扩展:AutoCompleteMode 允许有四种值 :Suggest 在ComboBox 中输入字符后, ComboBox 会自动展开,显示匹配的子项,输入行不受影响,需要自己输入后续 字符,或者在下拉框中点选完整子项。

App end:输入字符后,字符后会自动补充匹配内容 示),但是 ComboBox 不会展开。

按上下键可以在多个匹配内 容中切换。

SuggestA pp end:上述两种模式的组合。

AutoCompleteSource 属性,共有 9 种,指示自动完成将要在 其中进行查找的数据源。

常用的几种如下 :ListItems: 数据源为 ComboBox 的 Item 集合。

FileSystem: 文件系统。

例如输入 后会展开 下的目录列表(或 append 模式下的自动添加 )。

同样的,此数据源也支持文 件名的补全。

None:默认值,指示ComboBox 不使用自动功能。

(以反色显Customsource:自定义数据源。

选用此方式时必须在代码中指 定 ComboBox 的 AutoCompleteCustomSource 属性为你构建的 AutoCompletestringCollection 对象,否则不会生效。

AutoCompleteStringCollection 类似于 List ,将你的数据 add 进去即可。

[ 高质量编程 ]团队成员为您解答,请提出宝贵意见和建议。

谢谢!QQ:176229432补充回答 :首先我需要强调一点,使用拼音首字母检索时可能比较适合DropDownStyle=DropDownList 时。

ComboBox的使用方法

ComboBox的使用方法

Combo Box (组合框)控件很简单,可以节省空间。

从用户角度来看,这个控件是由一个文本输入控件和一个下拉菜单组成的。

用户可以从一个预先定义的列表里选择一个选项,同时也可以直接在文本框里面输入文本。

下面的例子简要说明如何利用 MFC CComboBox Class来操作字符串列表。

1、定义控件对应变量假定已经创建了一个Dialog,并且从控件工具箱将 Combo Box 控件拖放到上面。

打开 Class Wizard,添加控件对应变量,如:CComboBox m_cbExamble;在后面的代码中会不断使用这个变量。

2、向控件添加 Items1) 在Combo Box控件属性的Data标签里面添加,一行表示Combo Box下拉列表中的一行。

换行用ctrl+回车。

2)利用函数 AddString()向Combo Box 控件添加 Items,如:m_cbExample.AddString(“StringData1”);m_cbExample.AddString(“StringData2”);m_cbExample.AddString(“StringData3”);3)也可以调用函数 InsertString()将 Item插入指定位置 nIndex,如:m_cbExample.InsertString( nIndex, “StringData” );3、从控件得到选定的Item假设在控件列表中已经选定某项,现在要得到被选定项的内容,首先要得到该项的位置,然后得到对应位置的内容。

这里会用到两个函数,如:int nIndex = m_cbExample.GetCurSel();CString strCBText;m_cbExample.GetLBText( nIndex, strCBText);这样,得到的内容就保存在 strCBText中。

若要选取当前内容,可调用函数GetWindowText(strCBText)。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

ComboBoxhwndCtl为此组合框的句柄,lpsz为需要添加的字符串,组合框不能直接通过id添加内容,所以需要得到这个控件的句柄,还得使用GetDlgItem()函数.1C++添加内容ComboBox_AddString(hwndCtl,lpsz)举例:HWND hwndCombo1 = GetDlgItem(hwnd,IDC_C1);//建立一个组合框,ID可以设置为IDC_C1,然后通过GetDlgItem获取这个组合框的句柄//如果无法正常显示,需要调整此组合框的最大显示范围,在向下箭头上出现上下箭头时可以调整.ComboBox_AddString(hwndCombo1,TEXT("内容1"));ComboBox_AddString(hwndCombo1,TEXT("内容2"));//使用IDC_C1的句柄hwndCombo1,然后添加内容,多次调用可以设置多项文字,//添加的内容通常都放在Main_OnInitDialog()初始化函数中,也可以通过按钮或其他控件调用.[1]获取项目个数ComboBox_GetCount(hwndCtl)这个函数的返回值为int,参数hwndCtl为此组合框控件句柄;举例:HWND hwndCombo1 = GetDlgItem(hwnd,IDC_C1);int count = ComboBox_GetCount(hwndCombo1);//通过定义count拿到返回值.[1]删除内容ComboBox_DeleteString(hwndCtl, index)hwndCtl为句柄,index为项目索引号,从上至下,从0开始排列,所以0就是删除第一项.举例:HWND hwndCombo1 = GetDlgItem(hwnd,IDC_C1);ComboBox_DeleteString(hwndCombo1,0);[1]获取索引号ComboBox_GetCurSel(hwndCtl)此函数的返回值为int,返回项目索引号.举例:HWND hwndCombo1 = GetDlgItem(hwnd,IDC_C1);int count = ComboBox_GetCurSel(hwndCombo1);//获取到索引号.TCHAR str1[256];sprintf(str1,"当前选中的项索引号为:%d",count);//使用sprintf储存说明文字跟索引号,MessageBox(hwnd,str1,TEXT("标题"),MB_OK);ComboBox_DeleteString(hwndCombo1,count);//删除获取此索引号的项.MessageBox(hwnd,TEXT("删除当前选中的项"),TEXT("标题"),MB_OK);//为选中并删除当前项,如果没有选中任何项,返回值为-1.[1]给定选中并显示值ComboBox_SetCurSel(hwndCtl, index)位置的编号由0开始,0表示第一项举例:HWND hwndCombo1 = GetDlgItem(hwnd,IDC_C1);ComboBox_SetCurSel(hwndCombo1,2);//选择并显示第3项[1]给定并显示值ComboBox_GetLBText(hwndCtl, index, lpszBuffer)hwndCtl句柄,index索引号,lpszBuffer储存字符串举例:HWND hwndCombo1 = GetDlgItem(hwnd,IDC_C1);CString str;ComboBox_GetLBText(hwndCombo1,2, str);//ComboBox_GetLBText不返回值,实际是通过str储存并传递字符串.MessageBox(hwnd,str,TEXT("标题"),MB_OK);//输出某项的str字符串的值.[1]2VB控件在VB中,Combo Box(组合框)控件很简单,可以节省空间。

从用户角度来看,这个控件是由一个文本输入控件和一个下拉菜单组成的。

用户可以从一个预先定义的列表里选择一个选项,同时也可以直接在文本框里面输入文本。

改变下拉框大小1)直接在控件上操作,先点向下的箭头,就可以调整下拉框大小;2)为了让列表框变的更宽,可以用setdroppedwidth(int width)函数来调整列表框的宽度。

定义控件对应变量假定已经创建了一个Dialog,并且从控件工具箱将Combo Box 控件拖放到上面。

打开 Class Wizard,添加控件对应变量,如:CComboBox m_combo。

向控件添加Items1)在Combo Box控件属性的Data标签里面添加,一行表示Combo Box下拉列表中的一行。

换行用ctrl+回车。

若在VS2005中,Items间用";"隔开即可;2)利用函数 AddString()向 Combo Box 控件添加Items,如:m_combo.AddString(“StringData1”);m_combo.AddString(“StringData2”);m_combo.AddString(“StringData3”);3) 也可以调用函数 InsertString() 将 Item 插入指定位置 nIndex,如:m_combo.InsertString(nIndex, “StringData” );4)int GetCount( )可以得到当前列表框中行的数量。

示例代码:程序初始化时动态添加ItemsCString strTemp;m_combo.ResetContent();//消除现有所有内容for(inti=1;i<=100;i++){strTemp.Format("%d",i);m_combo.AddString(strTemp);}从控件得到选定的Item假设在控件列表中已经选定某项,现在要得到被选定项的内容,首先要得到该项的位置,然后得到对应位置的内容。

这里会用到两个函数,如:int nIndex = m_combo.GetCurSel();CString strText;m_combo.GetLBText( nIndex, strText);这样,得到的内容就保存在 strText 中。

若要选取当前内容,可调用函数GetWindowText(strText)。

在控件中查找给定Item这种操作一般用于在程序中动态修改控件中该项的值,可以用函数FindStringExact() 精确匹配,如:int nIndex =m_combo.FindStringExact( nStartAfter, “value to befound”);nStartAfter指明从哪一行开始查找。

如果查找成功,返回的是该项的位置;否则,返回CB_ERR。

也可以选中包含指定字符串的项,如:int nIndex =m_combo.SelectString( nStartAfter, “value to beselected”);删除控件中的Item该操作可以利用函数DeleteString(),需要指定被删除项的位置,如:m_combo.DeleteString(nIndex);也可以使用函数ResetContent(),清除目前的所有项,如:m_combo.ResetContent();显示控件中的某项int nIndex =m_combo.GetCurSel(); //当前选中的项m_combo.SetCurSel(nIndex); //设置第nIndex项为显示的内容取得Combo Box框内容1)取当前内容m_combo.GetWindowText(strTemp);2)取其他行内容m_combo.GetLBText(n,strTemp);获得焦点通常要判断控件是否获得了焦点,可以用GetFocus()函数,例如:if(GetFocus()==GetDlgItem(IDC_EDIT_VALUE2))//判断焦点是否在编辑框IDC_EDIT_VALUE2内。

但是combobox 的焦点不同,因为它是由edit和listbox两部分组成,所以获得焦点要用GetParent(),例如:if ((GetFocus()->GetParent())==GetDlgItem(IDC_COMBO_CF))。

设置控件属性1)Sort 属性:设置为 true,则新添加项将按字母顺序插入到列表中;否则,在列表的结尾处插入项。

2)Type属性:设置为Drop List,则使ComboBox不能输入只能在下拉菜单中选择;设置Dropdown,则ComboBox中允许输入内容。

3)No integral height属性,表示最大长度为设计长度,如果实际内容比设计长度多,就出现滚动条,少就以实际长度显示。

得到或设置输入框中被选中的字符位置1)DWORD GetEditSel() /BOOL SetEditSel( int nStartChar, int nEndChar );//得到或设置输入框中被选中的字符位置。

2)BOOL LimitText(int nMaxChars );//设置输入框中可输入的最大字符数。

常用的消息映射宏ON_CBN_DBLCLK 鼠标双击ON_CBN_DROPDOWN 列表框被弹出ON_CBN_KILLFOCUS /ON_CBN_SETFOCUS 在输入框失去/得到输入焦点时产生ON_CBN_SELCHANGE 列表框中选择的行发生改变ON_CBN_EDITUPDATE 输入框中内容被更新使用以上几种消息映射的方法为定义原型如:afx_msg void memberFxn( );的函数,并且定义形式如ON_Notification( id, memberFxn )的消息映射。

如果在对话框中使用组合框,Class Wizard会自动列出相关的消息,并能自动产生消息映射代码。

在.NET的Server Control中只有DropDownList,而不像Win Form编程一样有ComboBox,但是AjaxControlToolkit中提供了ComboBox,可以提供文本输入功能,并且有SuggestAppend功能。

与Textbox不同的是,ComboBox.Text属性并不能取得文本框中的文本,此属性与ComboBox.SelectedValue完全等同,只能获得下拉列表中的Value。

相关文档
最新文档