答复“博问”中网友对 ObjectDataSource 处理某问题的示例请求

本文介绍如何在ASP.NET的GridView控件中动态地为DropdownList填充数据。通过使用ObjectDataSource结合静态方法的方式,实现根据不同条件加载不同数量的选项。

原“问”地址 gridview中dropdownlist如何动态获取值?

答应给一个例子,不拖拉为好:)

将 DemoObjectQuery 放至 App_Code 某文件中:

ContractedBlock.gif ExpandedBlockStart.gif DemoObjectQuery
using System;
using System.Collections.Generic;
using System.Text;

[System.ComponentModel.DataObject]
public static class DemoObjectQuery {
    
private static System.Data.DataTable _prototypeTable = new System.Data.DataTable();
    
static DemoObjectQuery() {
        _prototypeTable.Columns.Add(
"Text");
        _prototypeTable.Columns.Add(
"Value");
    }

    [System.ComponentModel.DataObjectMethod(System.ComponentModel.DataObjectMethodType.Select)]
    
public static System.Data.DataTable SelectByNumber(int number) {
        System.Data.DataTable dt 
= _prototypeTable.Clone();
        
for (int i = 1; i <= number; i++) {
            dt.Rows.Add(
"(" + i + ")", i);
        }
        
return dt;
    }

    [System.ComponentModel.DataObjectMethod(System.ComponentModel.DataObjectMethodType.Select)]
    
public static System.Data.DataTable Select() {
        System.Data.DataTable dt 
= _prototypeTable.Clone();
        
for (int i = 10; i <= 30; i++) {
            dt.Rows.Add(
"[" + i + "]", i);
        }
        
return dt;
    }
}

 

创建如下 Test.aspx 示例文件:

ContractedBlock.gif ExpandedBlockStart.gif Test.aspx
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Test.aspx.cs" Inherits="Test" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    
<title></title>
</head>
<body>
    
<form id="form1" runat="server">
    
<div>
        
<asp:GridView ID="gv" runat="server" DataSourceID="obs" AutoGenerateColumns="False">
            
<Columns>
                
<asp:CommandField InsertVisible="False" ShowEditButton="True" />
                
<asp:BoundField DataField="Text" HeaderText="元素数" />
                
<asp:TemplateField HeaderText="下拉框效果">
                    
<EditItemTemplate>
                        
<asp:DropDownList runat="server" ID="ddl" DataSourceID="obsNumber" 
                            DataTextField
="Text" DataValueField="Value" ToolTip='<%# Eval("Value") %>
                            SelectedValue='
<%# Bind("Value"%>'>
                        
</asp:DropDownList>
                        
<asp:ObjectDataSource ID="obsNumber" runat="server" TypeName="DemoObjectQuery" SelectMethod="SelectByNumber"
                            OldValuesParameterFormatString
="original_{0}">
                            
<SelectParameters>
                                
<asp:ControlParameter Name="Number" ControlID="ddl" PropertyName="ToolTip" Type="Int32" />
                            
</SelectParameters>
                        
</asp:ObjectDataSource>
                    
</EditItemTemplate>
                
</asp:TemplateField>
            
</Columns>
        
</asp:GridView>
        
<asp:ObjectDataSource ID="obs" runat="server" TypeName="DemoObjectQuery" SelectMethod="Select"
            OldValuesParameterFormatString
="original_{0}"></asp:ObjectDataSource>
    
</div>
    
</form>
</body>
</html>

 

ContractedBlock.gif ExpandedBlockStart.gif Test.aspx.cs
using System;
using System.Collections.Generic;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

public partial class Test : System.Web.UI.Page {
    
protected void Page_Load(object sender, EventArgs e) {

    }    
}

c#的一个重要特征是“优雅”,事实上我也在平常的工作追求这种“无用”的所谓美观。当然,从技术服务于业务的角度说,无论怎样的实现方法,只要稳定、高效、安全就最好,表现方式或许不那么重要;只是在后期维护的过程中,后来人(也许还是开发者自己)将会十分受益!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值