I have a radgrid control and it's have a template column with itemtemplate
using TextBox
. When radgrid is loading then it showing all Data with NULL
textbox value. Now I want after load of radgrid, textbox value should be filled as per records based on my conditions which I am providing.
I have tried OnItemDataBound
, OnColumnCreated
Event but I was unable to get value of label.
Code are below:
<telerik:RadGrid ID="gridmaterial" runat="server" AutoGenerateColumns="false" AllowSorting="false" OnColumnCreated="gridmaterial_OnColumnCreated" OnItemDataBound="gridmaterial_OnItemDataBound" >
<MasterTableView AutoGenerateColumns="false" ShowHeadersWhenNoRecords="true">
<Columns>
<telerik:GridTemplateColumn UniqueName="RowSelect" AllowFiltering="false">
<HeaderStyle Width="5%" />
<ItemTemplate>
<asp:CheckBox runat="server" ID="chbxmatrow" ClientIDMode="Static" ViewStateMode="Enabled"/>
</ItemTemplate>
</telerik:GridTemplateColumn>
<telerik:GridTemplateColumn HeaderText="#" UniqueName="SerialNumber" AllowFiltering="false">
<HeaderStyle Width="5%" />
<ItemTemplate>
<asp:Label runat="server" ID="lblSNo" CssClass="control-label" ClientIDMode="Static" Text='<%# Container.DataSetIndex + 1 %>'></asp:Label>
</ItemTemplate>
</telerik:GridTemplateColumn>
<telerik:GridTemplateColumn HeaderText="Material Id" UniqueName="MasterMatId" Visible="false">
<HeaderStyle Width="40%" />
<ItemTemplate>
<asp:Label runat="server" ID="lblMaterialid" CssClass="control-label" ClientIDMode="Static" Text='<%# Eval("MasterMatID") %>'></asp:Label>
</ItemTemplate>
</telerik:GridTemplateColumn>
<telerik:GridTemplateColumn HeaderText="Group" UniqueName="Group">
<HeaderStyle Width="20%" />
<ItemTemplate>
<asp:Label runat="server" ID="lblMaterialGroup" CssClass="control-label" ClientIDMode="Static" Text='<%# Eval("Group") %>'></asp:Label>
</ItemTemplate>
</telerik:GridTemplateColumn>
<telerik:GridTemplateColumn HeaderText="Material Description" UniqueName="MasterMatDesc">
<HeaderStyle Width="50%" />
<ItemTemplate>
<asp:Label runat="server" ID="lblMaterialDesc" CssClass="control-label" ClientIDMode="Static" Text='<%# Eval("Description") %>'></asp:Label>
</ItemTemplate>
</telerik:GridTemplateColumn>
<telerik:GridTemplateColumn HeaderText="Qty" UniqueName="Qty" AllowFiltering="false">
<HeaderStyle Width="20%" />
<ItemTemplate>
<asp:TextBox runat="server" CssClass="form-control" ID="txtQty" ViewStateMode="Enabled" Width="100" onKeyPress="return isNumber(event);"></asp:TextBox>
</ItemTemplate>
</telerik:GridTemplateColumn>
</Columns>
</MasterTableView>
<ClientSettings>
<Scrolling AllowScroll="true" ScrollHeight="400px" />
</ClientSettings>
</telerik:RadGrid>
Code I have tried:
protected void gridmaterial_OnItemDataBound(object sender, GridItemEventArgs e)
{
foreach (GridDataItem item in gridmaterial.Items)
{
CheckBox rowcheck = (CheckBox)item.FindControl("chbxmatrow");
Label lblMaterialid = (Label)item.FindControl("lblMaterialid");
Label lblMaterialDesc = (Label)item.FindControl("lblMaterialDesc");
TextBox txtQty = (TextBox)item.FindControl("txtQty");
var result = (from r in MapppedItem.AsEnumerable() where r.Field<int>("MasterMatID") == Convert.ToInt32(lblMaterialid.Text) select r).ToList();
foreach (DataRow dr in result)
{
txtQty.Text=dr["BOMQty"].ToString();
rowcheck.Checked = true;
}
}
GridDataItem item = e.Item as GridDataItem;
GridColumn column = gridmaterial.MasterTableView.GetColumn("MasterMatId");
/*CheckBox rowcheck = (CheckBox)item.FindControl("chbxmatrow");
Label lblMaterialid = (Label)item.FindControl("lblMaterialid");
Label lblMaterialDesc = (Label)item.FindControl("lblMaterialDesc");
TextBox txtQty = (TextBox)item.FindControl("txtQty");*/
// int MatID = Convert.ToInt32(item.GetDataKeyValue("MasterMatId"));
// var result = (from r in MapppedItem.AsEnumerable() where r.Field<int>("MasterMatID") == Convert.ToInt32(MatID) select r).ToList();
// foreach (DataRow dr in result)
// {
// txtQty.Text = dr["BOMQty"].ToString();
// rowcheck.Checked = true;
// }
}
It is generating Null exception.
Please try with the below code snippet.
ASPX
<telerik:RadGrid ID="gridmaterial" runat="server" AutoGenerateColumns="false" AllowSorting="false" OnColumnCreated="gridmaterial_OnColumnCreated" OnItemDataBound="gridmaterial_OnItemDataBound">
<MasterTableView AutoGenerateColumns="false" ShowHeadersWhenNoRecords="true" DataKeyNames="MasterMatId">
<Columns>
<telerik:GridTemplateColumn UniqueName="RowSelect" AllowFiltering="false">
<HeaderStyle Width="5%" />
<ItemTemplate>
<asp:CheckBox runat="server" ID="chbxmatrow" ClientIDMode="Static" ViewStateMode="Enabled" />
</ItemTemplate>
</telerik:GridTemplateColumn>
<telerik:GridTemplateColumn HeaderText="#" UniqueName="SerialNumber" AllowFiltering="false">
<HeaderStyle Width="5%" />
<ItemTemplate>
<asp:Label runat="server" ID="lblSNo" CssClass="control-label" ClientIDMode="Static" Text='<%# Container.DataSetIndex + 1 %>'></asp:Label>
</ItemTemplate>
</telerik:GridTemplateColumn>
<telerik:GridTemplateColumn HeaderText="Group" UniqueName="Group">
<HeaderStyle Width="20%" />
<ItemTemplate>
<asp:Label runat="server" ID="lblMaterialGroup" CssClass="control-label" ClientIDMode="Static" Text='<%# Eval("Group") %>'></asp:Label>
</ItemTemplate>
</telerik:GridTemplateColumn>
<telerik:GridTemplateColumn HeaderText="Material Description" UniqueName="MasterMatDesc">
<HeaderStyle Width="50%" />
<ItemTemplate>
<asp:Label runat="server" ID="lblMaterialDesc" CssClass="control-label" ClientIDMode="Static" Text='<%# Eval("Description") %>'></asp:Label>
</ItemTemplate>
</telerik:GridTemplateColumn>
<telerik:GridTemplateColumn HeaderText="Qty" UniqueName="Qty" AllowFiltering="false">
<HeaderStyle Width="20%" />
<ItemTemplate>
<asp:TextBox runat="server" CssClass="form-control" ID="txtQty" ViewStateMode="Enabled" Width="100" onKeyPress="return isNumber(event);"></asp:TextBox>
</ItemTemplate>
</telerik:GridTemplateColumn>
</Columns>
</MasterTableView>
<ClientSettings>
<Scrolling AllowScroll="true" ScrollHeight="400px" />
</ClientSettings>
</telerik:RadGrid>
ASPX.CS
protected void gridmaterial_OnItemDataBound(object sender, GridItemEventArgs e)
{
if (e.Item is GridDataItem)
{
GridDataItem item = e.Item as GridDataItem;
CheckBox rowcheck = (CheckBox)item.FindControl("chbxmatrow");
Label lblMaterialDesc = (Label)item.FindControl("lblMaterialDesc");
TextBox txtQty = (TextBox)item.FindControl("txtQty");
var result = (from r in MapppedItem.AsEnumerable()
where r.Field<int>("MasterMatID") == Convert.ToInt32(item.GetDataKeyValue("MasterMatId").ToString())
select r.BOMQty).FirstOrDefault();
txtQty.Text = result;
}
}
Let me know if I am not understand your requirement.
The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.