简体   繁体   中英

How to change radgrid template column value after DataBound on Load

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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM