Ext.NET GridPanel 顶部栏工具栏按钮在 DirectEvent 上引发内部服务器错误 500 未在后面的代码中引发

Posted

技术标签:

【中文标题】Ext.NET GridPanel 顶部栏工具栏按钮在 DirectEvent 上引发内部服务器错误 500 未在后面的代码中引发【英文标题】:Ext.NET GridPanel topbar toolbar button raises Internal Server error 500 on DirectEvent Not raised in code behind 【发布时间】:2012-05-23 12:13:33 【问题描述】:

我将 Ext.NET 与 VS2008、ASP.NET 一起使用。我有一个独特的问题,我无法找到任何解决方案。

有一个 GridPanel,在 TopBar 中有一个删除按钮。 Grid 使用 RowSelection 模型。选择行后,用户单击删除按钮。引发客户端事件以进行确认,以下是代码 sn-p

<ext:Button ID="btnDelete" runat="server" Text="Delete" Icon="Delete">
                    <DirectEvents>
                        <Click OnEvent="Evt_Delete">
                        <ExtraParams>
                        <ext:Parameter Name="recordId" Value="(#grdSanction).selModel.getSelected().data.VoucherID" Mode="Raw" />
                        </ExtraParams>

                            <Confirmation Message="Do you really want to delete sanction?" ConfirmRequest="true"/>
                        </Click>
                    </DirectEvents>
                </ext:Button>

但问题是我在单击“是”后收到以下消息,基本上是 500 内部服务器错误。

以下是我在 Fiddler 中找到的内容:

结果协议主机 URL 正文缓存内容类型进程注释自定义 1 500 HTTP onyx /pages/sanction.aspx?_dc=1337773867270 4,268 私有文本/html; charset=utf-8 铬:920

VS2008 的调试器不工作,因为后面代码上的事件永远不会引发。 工具栏上的其他按钮工作得很好。有谁知道我在这里想念什么?

【问题讨论】:

【参考方案1】:

我认为您只需删除 #grdSantion 周围的圆括号即可。

// Not OK 
(#grdSanction).selModel.getSelected().data.VoucherID

// OK
#grdSanction.selModel.getSelected().data.VoucherID

以下示例演示了完整的场景,并且似乎可以根据您的要求工作。

示例

<%@ Page Language="C#" %>

<%@ Register Assembly="Ext.Net" Namespace="Ext.Net" TagPrefix="ext" %>

<script runat="server">
    protected void Page_Load(object sender, EventArgs e)
    
        if (!X.IsAjaxRequest)
        
            var store = this.GridPanel1.GetStore();

            store.DataSource = this.Data;
            store.DataBind();
        
    

    private object[] Data
    
        get
        
            return new object[]
            
                new object[]  "3m Co", 71.72, 0.02, 0.03, "9/1 12:00am" ,
                new object[]  "Alcoa Inc", 29.01, 0.42, 1.47, "9/1 12:00am" ,
                new object[]  "Altria Group Inc", 83.81, 0.28, 0.34, "9/1 12:00am" ,
                new object[]  "American Express Company", 52.55, 0.01, 0.02, "9/1 12:00am" ,
                new object[]  "American International Group, Inc.", 64.13, 0.31, 0.49, "9/1 12:00am" ,
                new object[]  "AT&T Inc.", 31.61, -0.48, -1.54, "9/1 12:00am" ,
                new object[]  "Boeing Co.", 75.43, 0.53, 0.71, "9/1 12:00am" ,
                new object[]  "Caterpillar Inc.", 67.27, 0.92, 1.39, "9/1 12:00am" 
            ;
        
    

    protected void Button1_Click(object sender, DirectEventArgs e)
    
        X.Msg.Notify("Company", e.ExtraParams["company"]).Show();
    
</script>

<!DOCTYPE html>

<html>
<head runat="server">
    <title>Ext.NET Example</title>
</head>
<body>
<form runat="server">
    <ext:ResourceManager runat="server" />

    <ext:GridPanel 
        ID="GridPanel1"
        runat="server" 
        Title="Array Grid" 
        Width="350" 
        Height="215">
        <TopBar>
            <ext:Toolbar runat="server">
                <Items>
                    <ext:Button runat="server" Text="Delete" Icon="Delete">
                        <DirectEvents>
                            <Click OnEvent="Button1_Click">
                            <ExtraParams>
                                <ext:Parameter Name="company" Value="#GridPanel1.selModel.getSelected().data.company" Mode="Raw" />
                            </ExtraParams>
                                <Confirmation Message="Do you really want to delete sanction?" ConfirmRequest="true"/>
                            </Click>
                        </DirectEvents>
                    </ext:Button>
                </Items>
            </ext:Toolbar>
        </TopBar>
        <Store>
            <ext:Store runat="server">
                <Reader>
                    <ext:ArrayReader>
                        <Fields>
                            <ext:RecordField Name="company" />
                        </Fields>
                    </ext:ArrayReader>
                </Reader>
            </ext:Store>
        </Store>
        <ColumnModel runat="server">
            <Columns>
                <ext:Column ColumnID="Company" Header="Company" DataIndex="company" />
            </Columns>
        </ColumnModel>
        <SelectionModel>
            <ext:RowSelectionModel runat="server" SingleSelect="true" />
        </SelectionModel>
    </ext:GridPanel>
</form>
</body>
</html>

【讨论】:

感谢您的回答。但奇怪的是,我发现问题在于工具栏的 ...EnableOverflow="true" 属性。真的很奇怪不是吗?我刚刚检查并检查了代码为什么其他网格正在工作而这个有问题。删除此属性完全消除了错误。我仍然不明白,但这就是真正发生的事情。如果我把 EnableOverflow 属性放回去,错误就会弹出。所以我确认了。不管怎样,谢谢。我已经删除了封装 # 内容的整个代码中的圆括号。

以上是关于Ext.NET GridPanel 顶部栏工具栏按钮在 DirectEvent 上引发内部服务器错误 500 未在后面的代码中引发的主要内容,如果未能解决你的问题,请参考以下文章

Ext.Net学习笔记15:Ext.Net GridPanel 汇总(Summary)用法

Ext.Net学习笔记16:Ext.Net GridPanel 折叠/展开行

Ext.Net学习笔记17:Ext.Net GridPanel Selection

Ext.Net学习笔记14:Ext.Net GridPanel Grouping用法

Ext.Net学习笔记13:Ext.Net GridPanel Sorter用法

Ext.Net学习笔记18:Ext.Net 可编辑的GridPanel