RadGrid中的文本框由客户端更改

时间:2012-11-22 05:22:17

标签: telerik radgrid radtextbox

美好的一天,

我有一个带有RadTextbox的GridTemplateColumn。文本框值由javascript更改。但是当我单击文本框时,它会更改回原始值。

请帮忙

的javascript

<title>Untitled Page</title>

<script type="text/javascript">
    function changeCountry() {            

        var grid = $find('<%=RadGrid1.ClientID %>');
        var MasterTable = grid.get_masterTableView();            
        var dataItems = MasterTable.get_dataItems();

        var cellCountry = dataItems[0].get_cell("CountryCol");
        var txtCountry = $telerik.$(cellCountry).find('input')[0];
        txtCountry.value = "New Country";        
    }
</script>

的.aspx     

    <telerik:RadGrid ID="RadGrid1" runat="server" AllowPaging="True" CellSpacing="0" GridLines="None" PageSize="20" AutoGenerateColumns="false" OnItemDataBound="RadGrid1_ItemDataBound">
        <FilterMenu EnableImageSprites="False">
        </FilterMenu>
        <ClientSettings>
            <Selecting CellSelectionMode="None" AllowRowSelect="True" />
        </ClientSettings>
        <MasterTableView>
            <CommandItemSettings ExportToPdfText="Export to PDF" />
            <RowIndicatorColumn FilterControlAltText="Filter RowIndicator column" Visible="True">
            </RowIndicatorColumn>
            <ExpandCollapseColumn FilterControlAltText="Filter ExpandColumn column" Visible="True">
            </ExpandCollapseColumn>                               
            <Columns>

                <telerik:GridBoundColumn DataField="CR_Branch" HeaderText="Branch"></telerik:GridBoundColumn>
                <telerik:GridBoundColumn DataField="CR_Country" HeaderText="Branch" Display=false></telerik:GridBoundColumn>

                <telerik:GridTemplateColumn HeaderText="CR_Country" DataField="CR_Country" UniqueName="CountryCol">
                    <ItemTemplate>                    
                        <telerik:RadTextBox ID="txtCountry" runat="server"></telerik:RadTextBox>                                                   
                    </ItemTemplate>
                </telerik:GridTemplateColumn>                                                

            </Columns>
            <EditFormSettings>
                <EditColumn FilterControlAltText="Filter EditCommandColumn column">
                </EditColumn>
            </EditFormSettings>
        </MasterTableView>
    </telerik:RadGrid>

.aspx.cs

protected void RadGrid1_ItemDataBound(object sender, GridItemEventArgs e)
{
    if (e.Item is GridHeaderItem)
    {
    }
    if (e.Item is GridDataItem)
    {
        GridDataItem dataItem = (GridDataItem)e.Item;

        RadTextBox txtCountry = ((RadTextBox)dataItem.FindControl("txtCountry"));
        txtCountry.Text = dataItem["CR_Country"].Text;

    }

}

1 个答案:

答案 0 :(得分:1)

您需要使用Telerik客户端脚本 set_value 功能,而不是纯粹的javascript / HTML,即

function changeCountry() {            

    var grid = $find('<%=RadGrid1.ClientID %>');
    var MasterTable = grid.get_masterTableView();            
    var dataItems = MasterTable.get_dataItems();

    dataItems[0].findControl("txtCountry").set_value("New Country");
}