ASP.NET updatePanel은 checkboxList 선택을 지 웁니다
-
19-08-2019 - |
문제
Ajax UpdatePanel 내에 ASP.NET CheckBoxList 컨트롤이 있습니다.
아래의 HTML과 함께 코드 (C#)를 포함하겠습니다.
나는 그것이 포스트를 통해 지속되지 않는 CheckboxList가있는 것이라는 것을 알았습니다.
BTW, 조금 지저분합니다. 프로토 타입입니다.
원래 CheckBoxList를 채우는 데 사용되는 방법입니다.
protected void BindCheckboxes()
{
chkBuildings.Items.Clear();
chkNeighborhoods.Items.Clear();
string city = ddlFindHome_Location.SelectedItem.Value.ToLower();
ResidentDataContext rdc = new ResidentDataContext(Utility.Lookup.GetResidentConnectionString());
var neighs = (from n in rdc.spNeighborhoods where n.vchCity.Equals(city) select n);
foreach (var neighborhood in neighs)
{
ListItem li = new ListItem();
li.Value = neighborhood.intNeighborhoodID.ToString();
li.Attributes["onclick"] = string.Format("document.getElementById('{0}').click();", btnNeighHack.ClientID);
li.Text = neighborhood.vchNeighborhood;
chkNeighborhoods.Items.Add(li);
}
var builds = (from b in rdc.spBuildings
join nb in rdc.spNeighborhoodBuildings on b.intBuildingID equals nb.intBuildingID
join n in rdc.spNeighborhoods on nb.intNeightborhoodID equals n.intNeighborhoodID
where n.vchCity.ToLower().Equals(city)
select b).Distinct();
foreach (var buildings in builds)
{
ListItem li = new ListItem();
li.Value = buildings.intBuildingID.ToString();
li.Text = buildings.vchName;
chkBuildings.Items.Add(li);
}
upNeighs.Update();
upBuilds.Update();
}
BindCheckboxes ()가 호출됩니다.
protected void ddlFindHome_Location_SelectedIndexChanged(object sender, EventArgs e)
{
BindCheckboxes();
}
이것은 다른 checkboxlist의 확인란을 채우기위한 포스트 백 메소드입니다.
protected void btnNeighHack_Click(object sender, EventArgs e)
{
List<int> neighs = new List<int>();
foreach (ListItem li in chkNeighborhoods.Items)
{
if (li.Selected)
neighs.Add(Convert.ToInt32(li.Value));
}
ResidentDataContext rdc = new ResidentDataContext(Utility.Lookup.GetResidentConnectionString());
var builds = (from b in rdc.spBuildings
join nb in rdc.spNeighborhoodBuildings on b.intBuildingID equals nb.intBuildingID
where neighs.Contains(nb.intNeightborhoodID)
select b.intBuildingID).Distinct();
foreach (ListItem li in chkBuildings.Items)
{
li.Selected = false;
}
foreach (ListItem li in chkBuildings.Items)
{
if (builds.Contains(Convert.ToInt32(li.Value)))
li.Selected = true;
}
upBuilds.Update();
}
ASP.NET HTML은 다음과 같습니다
<asp:UpdatePanel ID="upNeighs" runat="server" UpdateMode="Conditional">
<ContentTemplate>
<div style="font-weight: bold;">
Neighborhood
</div>
<div style="padding-top: 7px; padding-left: 3px;">
<input type="checkbox" id="chkNeighborhood_CheckAll" />Select All
</div>
<hr />
<div>
<asp:CheckBoxList ID="chkNeighborhoods" runat="server" />
<asp:Button style="display: none;" ID="btnNeighHack" runat="server"
onclick="btnNeighHack_Click" />
</div>
</ContentTemplate>
</asp:UpdatePanel>
<asp:UpdatePanel ID="upBuilds" runat="server" UpdateMode="Conditional">
<ContentTemplate>
<div style="padding-left: 6px; padding-top: 5px; font-weight: bold;">
Building
</div>
<div>
<asp:CheckBoxList ID="chkBuildings" runat="server" />
</div>
</ContentTemplate>
</asp:UpdatePanel>
Bindcheckboxes () 함수가 호출되었다고 언급 했어야했습니다.
protected void ddlFindHome_Location_SelectedIndexChanged(object sender, EventArgs e)
{
BindCheckboxes();
}
그래서 그것은 항상 포스트 백입니다. 그러나 나는 당신이 그것으로 무언가에 있을지도 모른다고 생각합니다.
해결책 3
추가 연구 후, 나는 컨트롤이 포스트를 통해 지속되지 않고보기 상태에서 떨어지고 있음을 발견했습니다. 따라서 다시 게시 할 때마다 귀중한 객체가 있습니다.
protected Control PostBackControl
{
get { return Page.FindControl(Request.Params.Get("__EVENTTARGET")); }
}
그러나 드롭 다운 목록의 값이 기본값이 아니며 모든 것을 반복하기 시작합니다.
PostbackControl이 드롭 다운 목록 일 때만 확인란 목록 만 바인딩하면 업데이트 패널의 모든 것이 스코프를 벗어나기 때문에 컨트롤이 바인딩되지 않습니다.
다른 팁
protected void BindCheckboxes()
{
if(!IsPostBack)
{
chkBuildings.Items.Clear();
chkNeighborhoods.Items.Clear();
string city = ddlFindHome_Location.SelectedItem.Value.ToLower();
ResidentDataContext rdc = new ResidentDataContext(Utility.Lookup.GetResidentConnectionString());
var neighs = (from n in rdc.spNeighborhoods where n.vchCity.Equals(city) select n);
foreach (var neighborhood in neighs)
{
ListItem li = new ListItem();
li.Value = neighborhood.intNeighborhoodID.ToString();
li.Attributes["onclick"] = string.Format("document.getElementById('{0}').click();", btnNeighHack.ClientID);
li.Text = neighborhood.vchNeighborhood;
chkNeighborhoods.Items.Add(li);
}
var builds = (from b in rdc.spBuildings
join nb in rdc.spNeighborhoodBuildings on b.intBuildingID equals nb.intBuildingID
join n in rdc.spNeighborhoods on nb.intNeightborhoodID equals n.intNeighborhoodID
where n.vchCity.ToLower().Equals(city)
select b).Distinct();
foreach (var buildings in builds)
{
ListItem li = new ListItem();
li.Value = buildings.intBuildingID.ToString();
li.Text = buildings.vchName;
chkBuildings.Items.Add(li);
}
upNeighs.Update();
upBuilds.Update();
}
}
시도해보십시오.
선택을 변경할 때마다 CheckBoxList를 지우면 선택한 항목도 지우게됩니다. 대신 page_load에 항목을로드합니다.
제휴하지 않습니다 StackOverflow