Выполните итерации по строкам/флажкам в RadGrid

У меня есть Telerik RadGrid с GridTemplateColumn, который содержит флажок, следующим образом:

<telerik:GridTemplateColumn HeaderText="MINE" UniqueName="MyTemplateColumn">
     <ItemTemplate>
          <asp:CheckBox id="MyCheckBox" runat="server"></asp:CheckBox>
     </ItemTemplate>
</telerik:GridTemplateColumn>

Я хочу установить поле, которое будет "проверено" на основе значения, считанного из базы данных. Я мог обработать событие ItemDataBound и считать базу данных, когда каждая строка связывается, но это приводит к n поискам. Вместо этого я хочу обработать DataBound и затем установить все значения сразу. Так, в том методе я хочу код как это:

// read all values from database first, then...
foreach(var chkbox in MyRadGrid.MasterTableView.Columns.FindByUniqueName("MyTemplateColumn").FindControl("MyCheckBox")) {
    chkbox.Checked = oneValue;
}

Это не работает, потому что FindControl не является методом GridColumn, и он не генерирует повторяемый список флажков. Чего корректный путь состоит в том, чтобы выполнить итерации через флажки в шаблонном столбце?Спасибо!

5
задан Tony L. 30 December 2014 в 15:44
поделиться

2 ответа

Telerik ответил мне на своих форумах и дал следующий ответ:

foreach (GridDataItem item in MyRadGrid.MasterTableView.Items) 
{ 
  CheckBox chk = (CheckBox)item.FindControl("MyCheckBox");
  // Set the value here
}

Надеюсь, это будет полезно для кого-то!

16
ответ дан 18 December 2019 в 09:48
поделиться

У меня та же проблема. Вот как я это сделал...

'Создал локальную хэш-таблицу для использования сейчас и в остальное время

Private _GroupMembers As New Hashtable

'Загрузил ее при загрузке страницы Private Function GetMembers() As Boolean

    Try

        Dim da As New DataAccess
        Dim ht As New Hashtable
        Dim i As Int16 = 0

        ht.Add("CAC", Session("cac"))
        ht.Add("GroupID", _GroupID)
        If da.GetData("rap_spGetGroupMemberList", ht) = True Then
            If da.SQLDataRows.HasRows Then
                While da.SQLDataRows.Read()
                    i = i + 1
                    _GroupMembers.Add(i, da.SQLDataRows("UserID"))
                End While
            End If
            da.SQLDataRows.Dispose()
        End If

        da = Nothing

    Catch ex As Exception
        Console.Write(ex.Message)
    End Try
End Function

'Проверяем на наличие содержимого Protected Sub RadGrid2_ItemDataBound(ByVal sender As Object, ByVal e As Telerik.Web.UI.GridItemEventArgs) Handles RadGrid2.ItemDataBound

    Try

        If e.Item.IsDataBound Then
            If Not e.Item.DataItem("UserID") Is Nothing Then
                If Not IsDBNull(e.Item.DataItem("UserID")) Then
                    Dim UserID As Long = e.Item.DataItem("UserID")
                    If _GroupMembers.ContainsValue(UserID) Then
                        e.Item.Selected = True
                    End If
                End If
            End If
        End If

    Catch ex As Exception
        Console.Write(ex.Message)
    End Try
End Sub
1
ответ дан 18 December 2019 в 09:48
поделиться
Другие вопросы по тегам:

Похожие вопросы: