MFC_Combo_Box_用法(下拉框)

 Combo Box(组合框)控件很简单,可以节省空间。从用户角度来看,这个控件是由一个文本输入控件和一个下拉菜单组成的。用户可以从一个预先定义的列表里选择一个选项,同时也可以直接在文本框里面输入文本。 
1.改变下拉框大小 
  1)直接在控件上操作,先点向下的箭头,就可以调整下拉框大小; 
  2)为了让列表框变的更宽,可以用setdroppedwidth(int width)函数来调整列表框的宽度。 
2.定义控件对应变量 
  假定已经创建了一个Dialog,并且从控件工具箱将Combo Box 控件拖放到上面。打开 Class Wizard,添加控件对应变量,如:CComboBox m_combo。 
3.向控件添加 Items 
  1)在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( )可以得到当前列表框中行的数量。   示例代码:程序初始化时动态添加Items   CString strTemp; 
  m_combo.ResetContent();//消除现有所有内容   for(inti=1;i<=100;i++)   { 
  strTemp.Format("%d",i);   m_combo.AddString(strTemp);   } 
4.从控件得到选定的Item 
  假设在控件列表中已经选定某项,现在要得到被选定项的内容,首先要得到该项的位置,然后得到对应位置的内容。这里会用到两个函数,如:   int nIndex = m_combo.GetCurSel();   CString strText; 
   m_combo.GetLBText( nIndex, strText); 
  这样,得到的内容就保存在 strText 中。若要选取当前内容,可调用函数GetWindowText(strText)。 
5.在控件中查找给定Item 
  这种操作一般用于在程序中动态修改控件中该项的值,可以用函数FindStringExact() 精确匹配,如: 
  int nIndex = m_combo.FindStringExact( nStartAfter, “value to befound”);   nStartAfter指明从哪一行开始查找。如果查找成功,返回的是该项的位置;否则,返回CB_ERR。 
  也可以选中包含指定字符串的项,如: 
  int nIndex = m_combo.SelectString( nStartAfter, “value to beselected”); 
6.删除控件中的Item 
  该操作可以利用函数DeleteString(),需要指定被删除项的位置,如:   m_combo.DeleteString(nIndex); 
  也可以使用函数ResetContent(),清除目前的所有项,如:   m_combo.ResetContent(); 
7.显示控件中的某项 
  int nIndex = m_combo.GetCurSel(); //当前选中的项 
  m_combo.SetCurSel(nIndex); //设置第nIndex项为显示的内容 
8.取得Combo Box框内容 
  1)取当前内容 
  m_combo.GetWindowText(strTemp);   2)取其他行内容 
  m_combo.GetLBText(n,strTemp); 
9.获得焦点 
  通常要判断控件是否获得了焦点,可以用GetFocus()函数,例如:   if(GetFocus()==GetDlgItem(IDC_EDIT_VALUE2))//判断焦点是否在编辑框IDC_EDIT_VALUE2内。 
  但是combobox 的焦点不同,因为它是由edit和listbox两部分组成,所以获得焦点要用GetParent(),例如: 
  if ((GetFocus()->GetParent())==GetDlgItem(IDC_COMBO_CF))。 
10.设置控件属性 
  1)Sort 属性:设置为 true,则新添加项将按字母顺序插入到列表中;否则,在列表的结尾处插入项。 
  2)Type属性:设置为Drop List,则使ComboBox不能输入只能在下拉菜单中选择;设置Dropdown,则ComboBox中允许输入内容。 
  3)No integral height属性,表示最大长度为设计长度,如果实际内容比设计长度多,就出现滚动条,少就以实际长度显示。 
11.得到或设置输入框中被选中的字符位置 
  1)DWORD GetEditSel() /BOOL SetEditSel( int nStartChar, int nEndChar );//得到或设置输入框中被选中的字符位置。 
  2)BOOL LimitText(int nMaxChars );//设置输入框中可输入的最大字符数。 
12.常用的消息映射宏 
  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会自动列出相关的消息,并能自动产生消息映射代码。
  • 2
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好!关于Java下框填写省市县,一般的做法是通过前端页面使用三个下框,分别表示选择省、市、县/区。用户先选择省份,然后根据省份的不同,动态加载该省份下的所有城市,用户再选择一个城市,再根据城市的不同,加载该城市下的所有县/区,用户最后选择一个县/区。 具体实现方法可以使用Ajax异步加载数据,通过后台查询数据库获取对应的省市县/区数据,然后在前端页面上动态生成下框选项,实现联动效果。 下面是一个简单的示例代码,供参考: HTML页面: ``` <select id="province" name="province"> <option value="">请选择省份</option> </select> <select id="city" name="city"> <option value="">请选择城市</option> </select> <select id="county" name="county"> <option value="">请选择县/区</option> </select> ``` JavaScript代码: ``` $(function() { // 加载省份数据 $.ajax({ url : 'getProvinceData',// 后台获取省份数据的接口 type : 'GET', dataType : 'json', success : function(data) { var options = '<option value="">请选择省份</option>'; $(data).each(function() { options += '<option value="' + this.provinceCode + '">' + this.provinceName + '</option>'; }); $('#province').html(options); } }); // 省份下框变化时,加载城市数据 $('#province').change(function() { var provinceCode = $(this).val(); if (provinceCode != '') { $.ajax({ url : 'getCityData',// 后台获取城市数据的接口 type : 'GET', dataType : 'json', data : { provinceCode : provinceCode }, success : function(data) { var options = '<option value="">请选择城市</option>'; $(data).each(function() { options += '<option value="' + this.cityCode + '">' + this.cityName + '</option>'; }); $('#city').html(options); $('#county').html('<option value="">请选择县/区</option>'); } }); } else { $('#city').html('<option value="">请选择城市</option>'); $('#county').html('<option value="">请选择县/区</option>'); } }); // 城市下框变化时,加载县/区数据 $('#city').change(function() { var cityCode = $(this).val(); if (cityCode != '') { $.ajax({ url : 'getCountyData',// 后台获取县/区数据的接口 type : 'GET', dataType : 'json', data : { cityCode : cityCode }, success : function(data) { var options = '<option value="">请选择县/区</option>'; $(data).each(function() { options += '<option value="' + this.countyCode + '">' + this.countyName + '</option>'; }); $('#county').html(options); } }); } else { $('#county').html('<option value="">请选择县/区</option>'); } }); }); ``` 后台Java代码: ``` // 获取省份数据 @RequestMapping(value = "/getProvinceData", method = RequestMethod.GET) @ResponseBody public List<Province> getProvinceData() { List<Province> provinceList = provinceService.findAllProvinces(); return provinceList; } // 获取城市数据 @RequestMapping(value = "/getCityData", method = RequestMethod.GET) @ResponseBody public List<City> getCityData(@RequestParam("provinceCode") String provinceCode) { List<City> cityList = cityService.findCitiesByProvinceCode(provinceCode); return cityList; } // 获取县/区数据 @RequestMapping(value = "/getCountyData", method = RequestMethod.GET) @ResponseBody public List<County> getCountyData(@RequestParam("cityCode") String cityCode) { List<County> countyList = countyService.findCountiesByCityCode(cityCode); return countyList; } ``` 需要注意的地方是,省市县/区的数据需要进行持久化存储,可以使用数据库或者其他方式进行存储。同时,需要在后台代码中提供相应的接口,供前端页面进行数据获取。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值