GridView에서 DropDownList 연결
7409 단어 GridView
using
System;
using
System.Collections.Generic;
using
System.Linq;
using
System.Web;
using
System.Web.UI;
using
System.Web.UI.WebControls;
using
System.Data;
public
partial
class
_Default : System.Web.UI.Page
{
protected
void
Page_Load(
object
sender, EventArgs e)
{
}
protected
void
GridView1_RowDataBound(
object
sender, GridViewRowEventArgs e)
{
//
if
(e.Row.RowType
==
DataControlRowType.DataRow)
{
DropDownList ddlParent
=
(DropDownList)e.Row.FindControl(
"
ddlParent
"
);
GetParent(ddlParent);
}
}
private
void
GetParent(DropDownList ddl)
{
string
sql
=
"
select * from Models where ParentModuleID=0
"
;
DataTable dt
=
DB.CreateDT(sql);
ddl.DataTextField
=
"
ModuleName
"
;
ddl.DataValueField
=
"
ID
"
;
ddl.DataSource
=
dt;
ddl.DataBind();
}
protected
void
ddlParent_SelectedIndexChanged(
object
sender, EventArgs e)
{
GridViewRow row
=
(GridViewRow)((sender)
as
Control).NamingContainer;
DropDownList ddlParent
=
(sender)
as
DropDownList;
int
ddlParentID
=
Convert.ToInt32(ddlParent.SelectedValue);
DropDownList ddlChildren
=
row.FindControl(
"
ddlChildren
"
)
as
DropDownList;
GetChildren(ddlChildren,ddlParentID);
}
private
void
GetChildren(DropDownList ddl,
int
parentID)
{
string
sql
=
"
select * from Models where ParentModuleID=
"
+
parentID
+
""
;
DataTable dt
=
DB.CreateDT(sql);
ddl.DataTextField
=
"
ModuleName
"
;
ddl.DataValueField
=
"
ID
"
;
ddl.DataSource
=
dt;
ddl.DataBind();
}
}
주의해야 할 것은 그 중의 NamingContaier의 사용 방식이다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
C#의 413은 DataGridView에서 Excel로 데이터 내보내기텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.