1、行双击事件

首先设置选择方式为RowSelectionModel单行选中

[html] view
plain
copy

  1. <SelectionModel>
  2. <ext:RowSelectionModel ID="RowSelectionModel1" runat="server" SingleSelect="true">
  3. </ext:RowSelectionModel>
  4. </SelectionModel>

1.1   注册行双击事件,响应代码写在前台js中

[html] view
plain
copy

  1. <Listeners>
  2. <RowDblClick Handler="return rowDbClick(#{GridPanel1},#{Store1})" />
  3. </Listeners>

前台js代码:

[javascript] view
plain
copy

  1. <script type="text/javascript">
  2. function FnRowDbClick(paramgrid, paramstore) {
  3. var row = paramgrid.getSelectionModel().getSelections(); //选择行的个数
  4. if (row == null || row == undefined || row.length == 0) {
  5. }
  6. paramID = row[0].data.员工编号.toString();
  7. paraName = row[0].data.姓名.toString();
  8. this.Window1.setTitle("[" + paraName + "] 迟发日期明细表");
  9. // this.Window1.Title("[" + paraName + "] 迟发日期明细表"); 错误
  10. this.Window1.show();
  11. }
  12. </script>

1.2 注册行双击事件,响应代码写在后台cs文件中

<DirectEvents>

             <RowDblClick OnEvent="Row_DblClick" > </RowDblClick>

</DirectEvents>

后台代码:

protected void OnRow_DblClick(object sender, DirectEventArgs e)

{

this.Window1.Title = "未发日期明细表";

this.Window1.Show();

}

1.3 定义带参数的行双击事件

注册事件

[html] view
plain
copy

  1. <DirectEvents>
  2. <RowDblClick OnEvent="Row_DblClick" >
  3. <ExtraParams>
  4. <ext:Parameter Name="ID" Value="(GridPanel1.getSelectionModel().getSelections())[0].data.员工编号.toString()" Mode="Raw" />
  5. <ext:Parameter Name="EmployName" Value="(GridPanel1.getSelectionModel().getSelections())[0].data.姓名.toString()" Mode="Raw" />
  6. <ext:Parameter Name="Name" Value="(GridPanel1.getSelectionModel().getSelections())[0].data" Mode="Raw" />
  7. <%--   <ext:Parameter Name="Values" Value="Ext.encode(#{GridPanel1}.getRowsValues())" Mode="Raw" />--%>
  8. <ext:Parameter Name="Values" Value="Ext.encode(#{GridPanel1}.getRowsValues({selectedOnly:true}))" Mode="Raw" />
  9. </ExtraParams>
  10. </RowDblClick>
  11. </DirectEvents>

后台代码:

[csharp] view
plain
copy

  1. protected void Row_DblClick(object sender, DirectEventArgs e)  //
  2. {
  3. string json = e.ExtraParams["Values"];
  4. string Key;
  5. Dictionary<string, string>[] dic = JSON.Deserialize<Dictionary<string, string>[]>(json);
  6. if (dic.Length > 0)   //选择当行时,获取选择行的数据
  7. {
  8. string ID1 = dic[0]["员工编号"].ToString();
  9. string Name1 = dic[0]["姓名"].ToString();
  10. string Out = dic[0]["出差总天数"].ToString();
  11. string Out2 = dic[0]["出差地点总数"].ToString();
  12. }
  13. else  //选择多行时,获取选择行的数据
  14. {
  15. foreach (Dictionary<string, string> row in dic)
  16. {
  17. foreach (KeyValuePair<string, string> keyValuePair in row)
  18. {
  19. Key = keyValuePair.Key;
  20. if (Key == "员工编号")
  21. {
  22. string ID = keyValuePair.Value;
  23. continue;
  24. }
  25. else if (Key == "姓名")
  26. {
  27. string Name = keyValuePair.Value;
  28. continue;
  29. }
  30. }
  31. }
  32. }
  33. }

2、单元格命令事件,cell command(ImageCommand),自定义事件参数

在列中定义ImageCommand

[html] view
plain
copy

  1. <ext:Column Header="未发次数" DataIndex="未发次数" Width="200">
  2. <Commands>
  3. <ext:ImageCommand CommandName="query" Icon="ApplicationViewList" Text="查看">
  4. <ToolTip Text="未发日期列表" />
  5. </ext:ImageCommand>
  6. </Commands>
  7. </ext:Column>

2.1  定自定事件及事件参数,后台响应事件

[html] view
plain
copy

  1. <DirectEvents>
  2. <Command OnEvent="OnCell_Click">
  3. <ext:Parameter Name="colName" Value="this.getColumnModel().getDataIndex(colIndex)" Mode="Raw" />
  4. </ExtraParams>
  5. <ExtraParams>
  6. <ext:Parameter Name="ID" Value="record.data.编号" Mode="Raw" />
  7. </ExtraParams>
  8. <ExtraParams>
  9. <ext:Parameter Name="Name" Value="record.data.姓名" Mode="Raw" />
  10. </ExtraParams>
  11. </Command>
  12. </DirectEvents>

定义后台响应代码:

[csharp] view
plain
copy

  1. protected void OnCell_Click(object sender, DirectEventArgs e)
  2. {
  3. string m_No = e.ExtraParams["ID"].ToString();
  4. string paraName = e.ExtraParams["Name"].ToString();
  5. string paraColName = e.ExtraParams["colName"].ToString();
  6. if(paraColName == "未发次数")
  7. {
  8. this.Window1.Title = "[" + paraName + "] 未发日期明细表";
  9. InfoBindNoSendDay();
  10. this.Window1.Show();
  11. }
  12. else  if(paraColName == "迟发次数")
  13. {
  14. this.Window2.Title = "[" + paraName + "] 迟发日期明细表";
  15. InfoBindDelaySendDay();
  16. this.Window2.Show();
  17. }
  18. }

2.2  定义事件,前台js响应事件

[html] view
plain
copy

  1. <Listeners>
  2. <Command Handler="cellClick(record.data,this.getColumnModel().getDataIndex(colIndex))" />
  3. </Listeners>

js代码

[javascript] view
plain
copy

  1. <script language="javascript" type="text/javascript">
  2. function cellClick(paradata,paraCol) {
  3. paramID = paradata.员工编号.toString();
  4. paraName = paradata.姓名.toString();
  5. if (paraCol == "未发次数") {
  6. this.Window1.setTitle = "[" + paraName + "] 未发日期明细表";
  7. //this.Window1.Title="[" + paraName + "] 迟发日期明细表";   // 不能这么写,没有效果                                    this.Window1.reload();
  8. this.Window1.show();
  9. }
  10. else if (paraCol == "迟发次数") {
  11. this.Window1.setTitle = "[" + paraName + "] 迟发日期明细表";
  12. this.Window1.show();
  13. }
  14. }
  15. </script>

3、单元格选中事件 定义行选中模式为单元格选中模式,

定义选中事件

[html] view
plain
copy

  1. <SelectionModel>
  2. <ext:CellSelectionModel runat="server">
  3. <DirectEvents>
  4. <CellSelect OnEvent="Cell_Click" />
  5. </DirectEvents>
  6. </ext:CellSelectionModel>
  7. </SelectionModel>

定义事件响应代码(可写在后台,也可以写在js中,注意要有runat="server"):

[javascript] view
plain
copy

  1. <script runat="server">
  2. protected void Cell_Click(object sender, DirectEventArgs e)
  3. {
  4. CellSelectionModel sm = this.GridPanel1.SelectionModel.Primary as CellSelectionModel;
  5. this.Label1.Html = string.Format("RecordID: {0}<br />Name: {1}<br />Value: {2}<br />Row: {3}<br />Column: {4}",
  6. sm.SelectedCell.RecordID, sm.SelectedCell.Name,
  7. sm.SelectedCell.Value, sm.SelectedCell.RowIndex.ToString(), sm.SelectedCell.ColIndex.ToString());
  8. }
  9. </script>

4、前台js事件与后台事件的执行顺序

在两种事件都定义的时候,默认情况下是先执行js事件,然后执行后台事件

例如:

[html] view
plain
copy

  1. <ext:Button Width="50" ID="ButFrist"  icon="ArrowUp" runat="server" Text="上一月" StandOut="true"
  2. style="padding:5px;">
  3. <DirectEvents>
  4. <Click OnEvent="btn_Click" ></Click>
  5. </DirectEvents>
  6. <Listeners>
  7. <Click Handler="selectFrist();" />
  8. </Listeners>
  9. </ext:Button>

默认先执行js代码

[javascript] view
plain
copy

  1. <script type="text/javascript">
  2. function selectFrist() {
  3. var t = ComboBox1.getValue();
  4. var i = ComboBox1.getSelectedIndex();
  5. if (i!=-1 && (i - 1) >= 0) {
  6. ComboBox1.selectByIndex(i - 1);
  7. GridPanel1.reload();
  8. }
  9. else {
  10. Ext.Msg.alert("提示", "已到达起始月份!");
  11. return false;
  12. }
  13. return true;
  14. }
  15. </script>

后执行cs代码:

protected void btn_Click(object sender, DirectEventArgs e)

 {

           ComboBox1.Text = string.Format("{0:yyyy年M月}", Convert.ToDateTime(ComboBox1.Text.ToString()).AddMonths(-1));

 }

如果要先执行后台代码后执行js代码,则定义事件时加一个参数delay="50"   ,设置滞后时间

[html] view
plain
copy

  1. <ext:Button Width="50" ID="ButFrist"  icon="ArrowUp" runat="server" Text="上一月" StandOut="true"
  2. style="padding:5px;">
  3. <DirectEvents>
  4. <Click OnEvent="btn_Click" ></Click>
  5. </DirectEvents>
  6. <Listeners>
  7. <Click Handler="selectFrist();" Delay="50" />
  8. </Listeners>
  9. </ext:Button>

转自:http://blog.csdn.net/alisa525/article/details/8081092

Ext.Net 1.x_Ext.Net.GridPanel 事件的更多相关文章

  1. Ext.Net 1.x_Ext.Net.GridPanel嵌套Checkbox

    解决办法:拼接HTML var tplchecked = '<input type="checkbox" {0}>'; var IsChecked = function ...

  2. Ext.Net 1.x_Ext.Net.GridPanel之Access数据库分页显示

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.D ...

  3. Ext.Net 使用总结之GridPanel的删除事件

    1.关于Ext.net中GridPanel的删除事件 首先是GridPanel,如下: <ext:GridPanel ID="GridPanel1" runat=" ...

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

    Ext.Net学习笔记18:Ext.Net 可编辑的GridPanel Ext.Net GridPanel 有两种编辑模式:编辑单元格和编辑行. 单元格编辑: 行编辑: 可以看出,单元格编辑的时候,只 ...

  5. Ext JS学习第十六天 事件机制event(一) DotNet进阶系列(持续更新) 第一节:.Net版基于WebSocket的聊天室样例 第十五节:深入理解async和await的作用及各种适用场景和用法 第十五节:深入理解async和await的作用及各种适用场景和用法 前端自动化准备和详细配置(NVM、NPM/CNPM、NodeJs、NRM、WebPack、Gulp/Grunt、G

    code&monkey   Ext JS学习第十六天 事件机制event(一) 此文用来记录学习笔记: 休息了好几天,从今天开始继续保持更新,鞭策自己学习 今天我们来说一说什么是事件,对于事件 ...

  6. Ext.NET 4.1.0 GridPanel数据分页

    针对大量数据在前端展示,需要进行分页显示,这里我使用的数据量为100万,数据存储在MongoDb中(也可以存储在本地文件或其它数据库中).最终显示效果如下: 步骤如下: 1.新建程序并配置,详见htt ...

  7. Ext JS 5的声明式事件监听

    在前文<在Ext JS 5使用ViewControllers>中,简单的介绍了Ext JS 5的一项重要改进——声明式事件监听.在本文,将深度探讨如何使用声明式事件监听啦简化应用程序的视图 ...

  8. Ext.Net 使用总结之GridPanel中的选中行

    1.判断GridPanel中是否选中了某行 if (!GridPanel1.hasSelection()) { Ext.Msg.alert("提示", "请选择记录!&q ...

  9. Ext JS学习第十七天 事件机制event(二)

    此文仅有继续学习笔记: 昨天说了三种邦定事件的方法,今天说一下自定义事件 假设现在又这样的情景一个自定义的事件 没有用到事件处理的场景        母亲问孩子和不饿->             ...

随机推荐

  1. JavaScript 函数定义

    JavaScript 使用关键字 function 定义函数. 函数可以通过声明定义,也可以是一个表达式. 函数声明 在之前的教程中,你已经了解了函数声明的语法 : function function ...

  2. 假设一个大小为100亿个数据的数组,该数组是从小到大排好序的,现在该数组分成若干段,每个段的数据长度小于20「也就是说:题目并没有说每段数据的size 相同,只是说每个段的 size < 20 而已」

    假设一个大小为100亿个数据的数组,该数组是从小到大排好序的,现在该数组分成若干段,每个段的数据长度小于20「也就是说:题目并没有说每段数据的size 相同,只是说每个段的 size < 20 ...

  3. Android自定义处理崩溃异常

    用过安卓手机的用户以及安卓开发者们会时长碰到程序异常退出的情况,普通用户遇到这种情况,肯定非常恼火,甚至会骂一生垃圾软件,然后卸载掉.那么开发者们在开发过程中遇到这种情况给怎么办呢,当然,你不可能世界 ...

  4. 集合框架之List接口

    有序的 collection(也称为序列).此接口的用户可以对列表中每个元素的插入位置进行精确地控制.用户可以根据元素的整数索引(在列表中的位置)访问元素,并搜索列表中的元素. 与 set 不同,列表 ...

  5. 在非ViewController中显示AlertController的方法

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 以前我们可以在任何类中使用UIAlertView的show实例 ...

  6. 第一行代码阅读笔记----显示隐式Intent的基本用法

    1.显示Intent意图明显,通过Intent启动另外一个活动,这是安卓中各组件进行交互的一种重要方式.一般用于启动活动,启动服务,发送广播等场景. 实现方法,这里我只说思路,实践还是要自己实操才能明 ...

  7. gitlab的搭建及问题的解决

    gitlab则是类似于github的一个工具,github无法免费建立私有仓库,并且为了代码安全,于是在内网安装了一个自己实验室的一个git服务器,gitlab有很多依赖,而bitnami制作了一键安 ...

  8. UNIX网络编程——TCP服务器“拒绝服务攻击” 解决方案

    前面的博客<<使用select和shutdown>>里面的拒绝服务型攻击也有提到. 说这是一个完全的解决方案,其实有点夸大了,但这个方案确实可以缓解TCP服务器遭受" ...

  9. XMLTABLE

     XMLTABLE Syntax Description of the illustration xmltable.gif XMLnamespaces_clause::= Description ...

  10. Cocoa触发方法调用的几种方法

    每日更新关注:http://weibo.com/hanjunqiang  新浪微博 1.SEL触发 SEL就是selector的缩写,它表示Cocoa中的方法选择器,不明白?那请仔细了解Objecti ...