1

我在 obout 网格的模板列中有一个下拉列表。目前我正在使用 sqldatasource 填充页面加载的下拉列表。但是,我现在必须根据某个列的值加载下拉列表。例如:如果状态 = 1,我使用与状态 1 相关的可用选项列表填充下拉列表。

<obout:Column ID="colStatus" DataField="wf_status_id" Align="center"  HeaderText="Status" HeaderAlign="center" Width="130px" Wrap="true" runat="server" AllowGroupBy="true" AllowFilter="true">
    <TemplateSettings EditTemplateId="tmpStatusIDEdit" TemplateId="tmpStatusID" />
</obout:Column>

<obout:GridTemplate runat="server" ID="tmpStatusID" >
    <Template>
        <%# Container.DataItem["Status"]%>
    </Template>
</obout:GridTemplate>
<obout:GridTemplate runat="server" ID="tmpStatusIDEdit" ControlID="ddlStatus" ControlPropertyName="value">
    <Template>
        <obout:OboutDropDownList runat="server" ID="ddlStatus" Width="100%" Height="200" MenuWidth="215" DataSourceID="sdsStatus" DataTextField="wf_status_text" DataValueField="wf_status_id" />
    </Template>
</obout:GridTemplate>

public void OnGridRowDataBound(object sender, Obout.Grid.GridRowEventArgs e)
{
     if (e.Row.RowType == Obout.Grid.GridRowType.DataRow)
     {
          DropDownList ddlStatus = new DropDownList();
          ddlStatus = (DropDownList)e.Row.FindControl("ddlStatus");
          //LOAD DROP DOWN HERE//
     }
}

当我尝试执行此代码时,它显示 ddlStatus 每次都为空。我尝试了多种方法来获得它,但由于某种原因似乎无法获得它。也许另一双眼睛或其他想法可以帮助我。请让我知道我做错了什么。提前谢谢你

更新:数据绑定事件代码

<obout:OboutDropDownList runat="server" ID="ddlStatus" Width="100%" Height="200" MenuWidth="215" OnDataBinding="ddlStatus_DataBinding" DataSourceID="sdsStatus" DataTextField="wf_status_text" DataValueField="wf_status_id" />

protected void ddlStatus_DataBinding(object sender, EventArgs e)
{
   Obout.Interface.OboutDropDownList ddl = (Obout.Interface.OboutDropDownList)(sender);
   string statusID = Eval("wf_status_id").ToString();
}

我添加了 DataSource,因为我看不到另一种触发数据绑定事件的方法。

4

2 回答 2

1

我对控件一无所知,obout但我不得不假设它们的行为与 asp.net 控件非常相似,并且刚刚被扩展。考虑到这一假设,我将尝试回答您的问题。

您的RowDataBound事件有一些编码问题...例如,我不确定您为什么要定义 anew DropDownList然后尝试用下一行覆盖它。而且听起来下一行null无论如何都会返回。

首先,我建议不要DataBound在行级别使用该事件。使用控件的DataBinding事件,因为它可以更好地本地化您的代码,因为您可以触发特定控件DataBinding,因此不必搜索它。如果您的代码更改(标记或代码隐藏),更改也容易得多,因为它不会影响其他事情并且引入错误的空间更小。

所以我会做出以下改变来解决这个问题:

更改您的DropDownList定义以实现DataBinding

<obout:OboutDropDownList runat="server" ID="ddlStatus" Width="100%" Height="200" 
    MenuWidth="215" OnDataBinding="ddlStatus_DataBinding" />

然后实现该事件(如果您没有将它用于其他任何事情OnDataBinding,请摆脱您的事件):DataBound

protected void ddlStatus_DataBinding(object sender, System.EventArgs e)
{
    // This will point to ddlStatus on the current row that is DataBinding so you
    // don't have to search for it.
    OboutDropDownList ddl = (OboutDropDownList)(sender);

    // Now you can fill the DropDownList and set the default value how ever you like
    ...
}

您还可以看到我很久以前回答的另一个问题,看看它是否有帮助,因为它正在做同样的事情,但使用 aRepeater但它与网格几乎相同:

在Repeater中填充DropDownList不起作用

编辑:更改了要OboutDropDownListDataBinding.

于 2014-09-05T13:56:57.203 回答
0

您可以在 obout 知识库和示例中找到大量示例。这些应该可以帮助您:http ://www.obout.com/combobox/aspnet_integration_grid.aspx,http : //www.obout.com/grid/aspnet_ajax_cascading_comboboxes.aspx

(它们指的是组合框,但您可以轻松地使它们适应 ddl)

于 2014-09-07T09:57:00.320 回答