Telerik RadGrid在编辑模式下会导致值异常

本文关键字:异常 RadGrid 编辑 模式 Telerik | 更新日期: 2023-09-27 17:59:02

我当然希望有人能在我还剩下一丝理智的时候帮助我:(

我有一个radgrid,通过LINQ查询进行数据绑定。它显示为它应该显示的,并且我添加了一个工作正常的详细信息按钮。但当我点击编辑按钮时,我会得到:"JavaScript运行时错误:Sys.WebForms.PageRequestManagerServerErrorException:选择超出范围参数名称:value"

我仔细研究了我得到的价值观,我没有发现任何问题,无论是明显的还是其他的。我的网格如下(对不起,有点乱):

 <telerik:RadGrid ID="RadGrid1" runat="server" AutoGenerateColumns="False" 
        CellSpacing="0" GridLines="None" AllowPaging="True" 
       DataMember="id" 
        onneeddatasource="RadGrid1_NeedDataSource" 
            OnUpdateCommand="RadGrid1_UpdateCommand" PageSize="20" 
            onitemcommand="RadGrid1_ItemCommand" >
<MasterTableView DataKeyNames="status,charity,make,model,year,vin,date,id,salePrice,bid,note" 
            EditMode="EditForms" EnableViewState="True">
<CommandItemSettings ExportToPdfText="Export to PDF"></CommandItemSettings>
<RowIndicatorColumn Visible="True" FilterControlAltText="Filter RowIndicator column">
<HeaderStyle Width="20px"></HeaderStyle>
</RowIndicatorColumn>
<ExpandCollapseColumn Visible="True" FilterControlAltText="Filter ExpandColumn column">
<HeaderStyle Width="20px"></HeaderStyle>
</ExpandCollapseColumn>
    <Columns>
    <telerik:GridButtonColumn CommandName="History" Text="History" UniqueName="detailBtn" HeaderText="History" HeaderButtonType="PushButton" AutoPostBackOnFilter="True">
                        </telerik:GridButtonColumn>
     <telerik:GridBoundColumn HeaderText="Charity" ItemStyle-Width="140px" FilterControlAltText="Filter column2 column" 
            UniqueName="column3" DataType="System.String" DataField="charity" ReadOnly="True">
<ItemStyle Width="140px"></ItemStyle>
        </telerik:GridBoundColumn>
         <telerik:GridBoundColumn HeaderText="VIN" ItemStyle-Width="140px" FilterControlAltText="Filter column6 column" 
            UniqueName="column7" DataType="System.String" DataField="vin" >
<ItemStyle Width="140px"></ItemStyle>
             </telerik:GridBoundColumn>
      <telerik:GridBoundColumn HeaderText="Year" ItemStyle-Width="140px" FilterControlAltText="Filter column2 column" 
            UniqueName="column2" DataType="System.Int32" DataField="year">
<ItemStyle Width="140px"></ItemStyle>
        </telerik:GridBoundColumn>
        <telerik:GridBoundColumn HeaderText="Make" ItemStyle-Width="140px" FilterControlAltText="Filter column column" 
            UniqueName="column" DataType="System.String" DataField="make">
<ItemStyle Width="140px"></ItemStyle>
        </telerik:GridBoundColumn>
        <telerik:GridBoundColumn HeaderText="Model" ItemStyle-Width="140px" FilterControlAltText="Filter column1 column" 
            UniqueName="column1" DataType="System.String" DataField="model">
<ItemStyle Width="140px"></ItemStyle>
            </telerik:GridBoundColumn>            
             <telerik:GridBoundColumn HeaderText="Last Update" ItemStyle-Width="140px" FilterControlAltText="Filter column1 column" 
            UniqueName="column5" DataType="System.DateTime" DataField="date" ReadOnly="True">
<ItemStyle Width="140px"></ItemStyle>
        </telerik:GridBoundColumn>
         <telerik:GridBoundColumn HeaderText="Min. Bid" ItemStyle-Width="140px" FilterControlAltText="Filter column1 column" 
            UniqueName="column8" DataType="System.Decimal" DataField="bid" DataFormatString="{0:C}" >
<ItemStyle Width="140px"></ItemStyle>
        </telerik:GridBoundColumn>
        <telerik:GridBoundColumn  HeaderText="Sale Price" ItemStyle-Width="140px" FilterControlAltText="Filter column1 column" 
            UniqueName="column6" DataType="System.Decimal" DataField="salePrice" DataFormatString="{0:C}" Display="False">
<ItemStyle Width="140px"></ItemStyle>
        </telerik:GridBoundColumn> 
        <telerik:GridBoundColumn  HeaderText="Notes" ItemStyle-Width="140px" FilterControlAltText="Filter column1 column" 
            UniqueName="unsoldNotesColumn" DataType="System.String" DataField="note" Display="True">
<ItemStyle Width="140px"></ItemStyle>
        </telerik:GridBoundColumn> 
      <telerik:GridTemplateColumn HeaderText="Latest Status" ItemStyle-Width="240px">

                        <ItemTemplate>
                            <%#DataBinder.Eval(Container.DataItem, "Status")%>
                        </ItemTemplate>

                        <EditItemTemplate>
                            <telerik:RadComboBox RenderMode="Lightweight" runat="server" ID="updateComboBox" DataTextField="Status" 
                                DataValueField="ID" DataSourceID="LinqDataSource1" SelectedValue='<%#Bind("ID") %>' AutoPostBack="True"
                                >
                            </telerik:RadComboBox>                          
                        </EditItemTemplate>

<ItemStyle Width="240px"></ItemStyle>

                    </telerik:GridTemplateColumn>
                    <telerik:GridEditCommandColumn FooterText="EditCommand footer" UniqueName="EditCommandColumn"
                        HeaderText="Edit" HeaderStyle-Width="100px" UpdateText="Update">
<HeaderStyle Width="100px"></HeaderStyle>
                    </telerik:GridEditCommandColumn>

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

我的代码指针,在与此有关的事件中是:

 private void LoadUnsoldVehicleGrid()
        {

            CAAData2DataContext db = new CAAData2DataContext();

            var ud = db.Updates
             .Where(c => c.Sold.Equals(false))
             .GroupBy(c => c.Vehicle)
            .Select(x => x.OrderByDescending(y => y.TimeStamp).First()).ToList();
            var unSoldVehicles = (from u in ud
                                  join v in db.Vehicles on
                                      u.Vehicle equals v.ID
                                  join c in db.Customers on
                                  v.Charity equals c.ID
                                  select new  
                                {
                                    status = u.Status,
                                    make = v.Make,
                                    model = v.Model,
                                    Year = v.Year,
                                    vin = v.VIN_,
                                    charity = c.Name,
                                    date = u.TimeStamp,
                                    id = u.Vehicle,
                                    salePrice = v.SalePrice,
                                    bid = v.MinimumBid,
                                    note=u.Note
                                }).OrderBy(z=>z.charity).ToList();
            RadGrid1.DataSource = unSoldVehicles;

        }

令人沮丧的是。。。这是有效的。我一定是无意中改变了什么,当我意识到这一切。。。ugh

如果有任何见解,我将不胜感激!

Paul

Telerik RadGrid在编辑模式下会导致值异常

<telerik:RadComboBox RenderMode="Lightweight" runat="server" ID="updateComboBox" DataTextField="Status" DataValueField="ID" DataSourceID="LinqDataSource1" SelectedValue='<%#Bind("ID") %>' AutoPostBack="True">
</telerik:RadComboBox>  

最有可能的是,问题来自上面的代码块。您可以做的是在RadComboBox控件上调用DataBind方法后,在代码后面设置SelectedValue。希望能有所帮助。

protected void RadGrid1_ItemDataBound(object sender, GridItemEventArgs e)
{
    if (e.Item.IsInEditMode) 
    {
        GridEditableItem editItem = (GridEditableItem)e.Item;
        RadComboBox combo = (RadComboBox)editItem.FindControl("updateComboBox"); 
        combo.DataBind(); 
        combo.SelectedValue = DataBinder.Eval(editItem.DataItem,"ID").ToString();
    }
}