5

次のように、チェックボックスを含むGridTemplateColumnを持つTelerikRadGridがあります。

<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のメソッドではなく、チェックボックスの反復可能なリストを生成しないため、これは機能しません。テンプレート列のチェックボックスを繰り返す正しい方法は何ですか?ありがとう!

4

2 に答える 2

16

Telerikは、次のように、彼らのフォーラムで答えを返してくれました。

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

これが誰かに役立つことを願っています!

于 2010-04-07T16:23:55.267 に答える
1

私は同じ問題を抱えています..これは私がそれをした方法でした..

'現在およびその他の方法で使用するローカルハッシュテーブルを作成しました

Private _GroupMembers As New Hashtable

'ページロード時にロードしましたPrivateFunctionGetMembers()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

'保護されたサブ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
于 2010-06-09T03:16:09.653 に答える