GridView模板列中使用函数进行绑定,如何带参数呢?(100分相求)

netspies 2008-05-13 07:39:08
例:
ASPX文件是这样写的
<asp:DropDownList ID="L_Gycs" runat="server" DataSource='<%# CreateDataSource_Gycs() %>' DataTextField="gysjc"  DataValueField="GysID" AppendDataBoundItems="true" >
</asp:DropDownList>

CreateDataSource_Gycs()是CS文件中的一个函数,如下:

protected DataTable CreateDataSource_Gycs( )
{
DataSet mydataset = null;
SQLHelper sqlhelper = new SQLHelper();
sqlhelper.RunSQL("select gysid=ID,gysjc from C_gysgl order by ID", ref mydataset);
return mydataset.Tables[0];
}
======================
我的问题是,希望能在函数中带一个动态的参数,参数是每行记录某字段的值(如SEX),如下:

<asp:DropDownList ID="L_Gycs" runat="server" DataSource='<%# CreateDataSource_Gycs("SEX") %>' DataTextField="gysjc"  DataValueField="GysID" AppendDataBoundItems="true" >
</asp:DropDownList>

然后CS文件函数中接收此字段的值,动态SQL语句的Where 条件,这样就不会显示全部数据,只显示相关的下拉选择.

我上面那个SEX系统没有当作字段内容,而是作为了一个SEX字符进行了处理,怎样将SEX字段的值返回函数呢?

谢谢各位了!


...全文
160 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
阿非 2008-05-14
  • 打赏
  • 举报
回复
[Quote=引用楼主 netspies 的帖子:]
例:
ASPX文件是这样写的
<asp:DropDownList ID="L_Gycs" runat="server" DataSource=' <%# CreateDataSource_Gycs() %>' DataTextField="gysjc"  DataValueField="GysID" AppendDataBoundItems="true" >
</asp:DropDownList>

CreateDataSource_Gycs()是CS文件中的一个函数,如下:

protected DataTable CreateDataSource_Gycs( )
{
DataSet mydataset = null;
SQLHelper sqlhelper =…
[/Quote]

<asp:DropDownList ID="L_Gycs"
是模版列的内容?

如果是的话


点下这里

你根据自己的需要简单修改下就可以了
netspies 2008-05-14
  • 打赏
  • 举报
回复
好, 谢谢大家,我先测试一下.
weiyue_net 2008-05-13
  • 打赏
  • 举报
回复
Sorry, that line should be:

ddl.DataSource = CreateDataSource_Gycs( e.Row.DataItem ("SEX"));
weiyue_net 2008-05-13
  • 打赏
  • 举报
回复
似乎没别的办法,只能在RowCreated事件中绑定

<asp:GridView ID="gvStates" AutoGenerateColumns="false"     runat="server" OnRowCreated="gvStates_RowCreated">
<Columns>
<asp:BoundField HeaderText="State" DataField="Name" />
<asp:TemplateField HeaderText="Cities">
<ItemTemplate>
<asp:DropDownList ID="ddlCities"AutoPostBack="true" runat="server" OnSelectedIndexChanged="ddlCities_SelectedIndexChanged">
</asp:DropDownList>
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>
<asp:Label ID="lblCity" runat="server" Text="Label">
</asp:Label>


	protected void gvStates_RowCreated(object sender, GridViewRowEventArgs e)
{
if (!IsPostBack)
{
if (e.Row.RowType == DataControlRowType.DataRow)
{
// Bind drop down to cities
DropDownList ddl = (DropDownList)e.Row.FindControl("ddlCities");
ddl.DataSource = CreateDataSource_Gycs( e.Row.DataItem ("SEX"));
ddl.DataBind();
}
}
}
晓风残月0110 2008-05-13
  • 打赏
  • 举报
回复
2

ItemTemplate>
<asp:Label ID="lbSex" runat="server" Text='<%#ChangeSex(DataBinder.Eval(Container,"DataItem.Sex").ToString()) %>'></asp:Label>
</ItemTemplate>


protected string ChangeSex(string str)
{
if (str != null && str != "")
{
switch (Convert.ToInt32(str))
{
case 0:
return "男";
break;
case 1:
return "女";
break;
default:
return "";
break;
}
}
else
return "";
}

晓风残月0110 2008-05-13
  • 打赏
  • 举报
回复
1

<ItemTemplate>
<asp:Label ID="LblYesFollow" runat="server" Text='<%#DataBinder.Eval(Container,"DataItem.HaveYear").ToString()=="1"?"有":"无"%>'></asp:Label>
</ItemTemplate>
晓风残月0110 2008-05-13
  • 打赏
  • 举报
回复
可以

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧