Ext.net中Combobox如何绑定数据库中的值-通用方法
今天在项目中再次碰到了问题,就是Combobox中的值如果是直接绑定很简单。简单添加项就行了。代码如下: <ext:ComboBox ID="ComBox_Sex" runat="server" FieldLabel="性别" Width="" EmptyText="请选择性别..." >
<Items>
<ext:ListItem Text="男性" Value=""/>
<ext:ListItem Text="女性" Value="" />
</Items>
</ext:ComboBox> 一、但是要从数据库中获取绑定该如何操作呢?
官方例子是用的后台数组做的,下面用 datatable来实现如下: 在页面中,首先是aspx页面的代码:
<form id="form1" runat="server">
<ext:ResourceManager ID="ResourceManager1" runat="server"/>
<ext:Store ID="Store_SexCom" runat="server">
<Reader>
<ext:JsonReader>
<Fields>
<ext:RecordField Name="SexID" Type="Int"/>
<ext:RecordField Name="SexName" Type="String" />
</Fields>
</ext:JsonReader>
</Reader>
</ext:Store> <ext:ComboBox ID="cboxSex" runat="server" FieldLabel="性别" Width="" EmptyText="请选择性别..." StoreID="Store_SexCom" ValueField="SexID" DisplayField="SexName">
</ext:ComboBox>
</form>
</body>
</html> 后台.cs文件代码:
protected void Page_Load(object sender, EventArgs e)
{
if (!X.IsAjaxRequest)
{
//首次加载时执行
DataSet ds_Com= getSex(); //返回的值是DataSet类型的数据
DataTable dt_Com = ds_Com.Tables[0];
//获取表中数据,Combobox一般的参数都是两个:Value传递的参数和Test显示的值
List<object> list = new List<object>(dt_Com.Rows.Count);
foreach (DataRow dr_Com in dt_Com.Rows) //遍历获取两个值
{
list.Add(new
{
SexID =Int32.Parse( dr_Com["SexID"].ToString()), SexName = dr_Com["SexName"].ToString()
}); }
Store_SexCom.DataSource = list;
//绑定数据
Store_SexCom.DataBind();
}
} 这样,简单的数据绑定就实现了,其实还是挺简单的吧。 二、上面的方法虽然看起来挺清晰的,但用起来还是有点麻烦,那么下面就来个更简单更直观的方法吧: DataSet ds= getSex();
DataTable dt= ds.Tables[];
//获取表中性别下拉数据参数都是两个:Value传递的参数和Test显示的值
foreach (DataRow dr in dt.Rows) //遍历获取两个值
{
Ext.Net.ListItem liSex= new Ext.Net.ListItem();
//每次创建一个Ext.Net.ListItem的对象
liSex.Value = dr["SexID"].ToString();
liSex.Text = dr["SexName"].ToString();
ComBox_Sex.Items.Add(liSex);
}
} 分别遍历的把每行的值赋值给该对象的Text和Value属性。然后用Items.Add(liSex)的方法添加到List中即可。 主要思想也就是把每个dr转换成一个listItem放进到Combox里
三、解决combox中增加"全部"选项处理方式:
下拉框Combox绑定数据源,增加一个“全部”。再进行数据绑定、或者像二中进行listitem项增加方法同样适用。WarningOnDirty="false" 四、其实上面的方法已经很简单明了了,但我们还要进行再简化或者做成通用。代码如下: /// <summary>
/// 绑定下拉框列表
/// </summary>
/// <param name="userInfo">用户信息</param>
/// <param name="comboBox">下拉框</param>
/// <param name="itemCode">编码</param>
/// <param name="addAllItem">是否增加全部</param>
public static void GetItemDetails(BaseUserInfo userInfo, ComboBox comboBox, string itemCode, bool addAllItem = true)
{
DataTable dataTable = SNFService.Instance.ItemDetailsService.GetDataTableByCode(userInfo, itemCode);
Ext.Net.ListItem listItem;
//设置“全部”选项
if (addAllItem)
{
listItem = new Ext.Net.ListItem();
listItem.Value = ItemListCategory.All.ToString();
listItem.Text = AppMessage.All;
comboBox.Items.Add(listItem);
comboBox.Select(listItem);
}
//设置"下拉"数据项
foreach (DataRow dr in dataTable.Rows)
{
listItem = new Ext.Net.ListItem();
listItem.Value = dr[BaseItemDetailsEntity.FieldItemValue].ToString();
listItem.Text = dr[BaseItemDetailsEntity.FieldItemName].ToString();
comboBox.Items.Add(listItem);
}
}
Ext.net中Combobox如何绑定数据库中的值-通用方法的更多相关文章
- Ext.net中Combobox如何绑定数据库中的值
]; ]; " /> </Items> </ext:ComboBox>
- Sliverlight linq中的数组筛选数据库中的数据
首先 什么是linq呢 ? LINQ即Language Integrated Query(语言集成查询),LINQ是集成到C#和Visual Basic.NET这些语言中用于提供查询数据能力的一个新特 ...
- MyBatis中使用实体中使用枚举,数据库中使用数值
一.简介 本文主要讲MyBatis中使用实体中使用枚举,数据库中使用数值的解决方案.正常直接使用会报错,需要添加typeHandlers在mybatis-config.xml中. 二.解决方案 如下: ...
- Python:判断文本中的用户名在数据库中是否存在,存在返回1,不存在返回0
下面是我写的python的一个小脚本,作用是:判断文本中的用户名在数据库中是否存在,存在返回1,不存在返回0.用的是MySQL数据库. 要注意的是:strip函数的使用,该函数的作用是去除字符串两端多 ...
- 解决SpringDataJpa实体类中属性顺序与数据库中生成字段顺序不一致的问题
一.在application.yml配置中添加数据库根据实体类自动创建数据库表的配置(这里数据库采用MySQL数据库) jpa: database: MYSQL show-sql: true #Hib ...
- 检验Excel中数据是否与数据库中数据重复
#region 记录Excel中的重复列 /// <summary> /// 记录Excel中的重复列 /// </summary> /// <param name=&q ...
- jQuery中设置form表单中action的值的方法
下面介绍在jQuery中设置form表单中action的值的方法. $("#myFormId").attr("action", "userinfo.s ...
- Java连接MySQL数据库增删改查通用方法
版权声明:本文为博主原创文章,未经博主允许不得转载. Java连接MySQL数据库增删改查通用方法 运行环境:eclipse+MySQL 以前我们Java连接MySQL数据库都是一个数据库写一个类,类 ...
- c# 在datagridview中添加comboboxcolumn 绑定数据库读取显示数据
datagridview中的comboboxcolumn 从绑定的数据库中读取显示时,只需要注意一点,就是sql语句加个 CStr() 字符串转换函数即可,如下: SELECT CStr(XXX) a ...
随机推荐
- Android -- 程序启动画面 Splash
很多应用都会有一个启动界面.欢迎画面慢慢隐现,然后慢慢消隐. 我的方式是使用两个Activity,程序启动时候load第一张Activity,然后由tick触发N秒钟后startActivity另外一 ...
- 开学了!这些Linux认证你要知道
大家好,今天我们将认识一些非常有价值的全球认可的Linux认证.Linux认证是不同的Linux专业机构在全球范围内进行的认证程序.Linux认证可以让Linux专业人才可以在服务器领域或相关公司等等 ...
- Oracle设置为自启动
Oracle设置为自启动 学习了:http://blog.itpub.net/31015730/viewspace-2148412/ oracle自带dbstart命令,主要进行系统启动设置: 在/e ...
- Linux:编译动态库时遇到的错误relocation R_X86_64_32 against `a local symbol'
编译动态库时遇到如下错误: ... ... relocation R_X86_64_32 against `a local symbol' can not be used when making a ...
- EM算法求高斯混合模型參数预计——Python实现
EM算法一般表述: 当有部分数据缺失或者无法观察到时,EM算法提供了一个高效的迭代程序用来计算这些数据的最大似然预计.在每一步迭代分为两个步骤:期望(Expectation)步骤和最大化( ...
- 使用socket BPF/Linux内核工程导论——网络:Filter(LSF、BPF、eBPF)
使用socket BPF linux 下的 包过滤器 BPF Linux内核工程导论——网络:Filter(LSF.BPF.eBPF) 注意(文中描述的内容): 此外,这段BPF代码还存在的一个问题是 ...
- java web下串口通讯
最近在做java串口通讯,主要是用个人电脑通过串口从RS485读取数据,并通过crc循环冗余校验,把接收正确的数据解析,插入数据库mysql,并用SSH技术把数据库数据以表格以及图表形式显示 ...
- 1z0-052 q209_2
2: View the Exhibit to examine the output produced by the following query at three different times s ...
- html中title属性换行实现
本文主要讲解titile属性换行的实现方式.<title> 元素可定义文档的标题,可以应用在img.a等标签上. 1.实现方式: <!DOCTYPE html> <htm ...
- html 语义化标签拾遗
1.del和ins标签 兼容性:浏览器全部支持 del:定义文档中已被删除的文本. ins:定义已经被插入文档中的文本. <!DOCTYPE html> <html lang=&qu ...
WarningOnDirty="false"
四、其实上面的方法已经很简单明了了,但我们还要进行再简化或者做成通用。代码如下:
/// <summary>