《仔仔细细分析Ext》 第N-2章 GridPanel的小难点 第一节 每条数据后面跟随几个操作按钮...

本文主要是介绍《仔仔细细分析Ext》 第N-2章 GridPanel的小难点 第一节 每条数据后面跟随几个操作按钮...,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《仔仔细细分析Ext》 第N-2章 GridPanel的小难点 第一节 每条数据后面跟随几个操作按钮

EXT QQ JavaScript 脚本 工作

导言:
      这是一篇学习笔记。
      虽然用GridPanel来展示数据稍微有那么一点死板,从视觉效果上看,呵呵。
      但是,有时候还是不得不用。
      相信拿GridPanel做基本的数据展示大家都是没有问题的,实在不记得还可以参考/examples/grid目录下的grid3.html这个例子(版本:Ext2.2)。
      这个里面有个小难点,我刚开始学Ext的时候碰到过,后来也有人问过我。需要实现的界面格式是这样的:
    


 

      或者用图标的形式:
    


 
   
      其实这里说的“小难点”指的是每条数据后面的那几个链接或者小按钮。说实话之前做过这个界面,但是这部分代码是别人写的,我以为很简单,就没去看。前段时间有人问我这个问题,我硬生生一点说不出来,汗。。。今天有点空,仔细看了一把,很熟悉的大侠就不用看了,时间宝贵,呵呵。
下面来小分析一把这种展示界面,权且称作“Ext标准grid展示”吧。

 


分析:
    


 
    如图所示,这种界面分几大块,这里只关注右侧的这些链接或者按钮的实现,其它的部分是很简单的,所以略去。
    第一种做法:使用渲染器renderer
    关注一下ColumnModel的写法就可以了。

Js代码   收藏代码
  1. var cm=new Ext.grid.ColumnModel([  
  2.     sm,  
  3.     rowNum,  
  4.     {header: "姓名", dataIndex:'name',width: 100, sortable: true},  
  5.     {header: "年龄", dataIndex:'age',width: 50, sortable: true},  
  6.     {header: "工作", dataIndex:'work',width: 150, sortable: true},  
  7.     {header: "公司", dataIndex:'company',width: 100, sortable: true},  
  8.     {header: "所属行业", dataIndex:'industry',width: 80, sortable: true},  
  9.     {header: "群", dataIndex:'QQ',width:150, sortable: true},  
  10.     {header: "操作", dataIndex:'id',width:150, sortable: true,renderer:function(value,meta,record){  
  11.           var resultStr = "<div class='controlBtn'>" +  
  12.                             "<a href='javascript:void("+record.get('id')+");' class='alarm_detail'>详细</a>&nbsp;&nbsp;&nbsp;& nbsp;" +  
  13.                             "<a href='javascript:void("+record.get('id')+");' class='alarm_detail'>删除</a>&nbsp;&nbsp;&nbsp;& nbsp;" +  
  14.                             "<a href='javascript:void("+record.get('id')+");' class='alarm_detail'>图表</a>&nbsp;&nbsp;&nbsp;& nbsp;" +  
  15.                             "<a href='javascript:void("+record.get('id')+");' class='alarm_detail'>曲线</a>&nbsp;&nbsp;&nbsp;& nbsp;" +  
  16.                             "</div>";  
  17.           return resultStr;  
  18.         }  
  19.     }  
  20. ]);  

 

     这个写法的优点是:代码比较优雅,不显乱;
     缺点是:这里面有个作用域的问题。因为做成链接这种形式,事件不是用Ext的实现来绑定的,而实际上使用了原生的事件,所以在点击之后的处理上稍微麻烦。
    2009-07-27日补充:这里是我糊涂了,忘了原生事件的作用域,这个问题可以用如下的方式来解决,幸亏“天猪”提醒,代码如下:

Js代码   收藏代码
  1. /** 
  2.  * 点击操作:注意这个地方的作用域问题,因为<a href="#" οnclick="dleUser()"> 
  3.  * 这里的onclick作用域是window 
  4.  */  
  5. window.delUser=function(userName){  
  6.     alert("开始删除"+userName);  
  7. }  
  8.   
  9. /** 
  10.  * 渲染器 
  11.  */  
  12. var opeartionRender=function(userName){  
  13.     return '<a href="#" οnclick="delUser('+userName+')">删除</a>';  
  14. }  
  15.   
  16. /** 
  17.  * 数据列模型 
  18.  */  
  19. var cm=new Ext.grid.ColumnModel([  
  20.     sm,  
  21.     rowNum,  
  22.     {header: "姓名", dataIndex:'name',width: 100, sortable: true},  
  23.     {header: "年龄", dataIndex:'age',width: 50, sortable: true},  
  24.     {header: "工作", dataIndex:'work',width: 150, sortable: true},  
  25.     {header: "公司", dataIndex:'company',width: 100, sortable: true},  
  26.     {header: "所属行业", dataIndex:'industry',width: 80, sortable: true},  
  27.     {header: "群", dataIndex:'QQ',width:150, sortable: true},  
  28. {header: "操作", dataIndex:'name',width:150, sortable: true,renderer:opeartionRender}  
  29. ]);  
 


   
     第二种做法:使用别人封装好的Ext.ux.RowActions组件
     整体代码和需要的资源见附件。
    (注意:附件里面有agrid.js和agrid2.js两个js,一次导入一个来查看两种不同的实现效果。图标所用的图片就自己找吧。导入Ext和演示脚本的相对路径请改成你本机的有效路径)
     RowActions的问题是代码不够优雅,按钮的那些东西硬生生地入侵到了cm和gridPanel里面去了,更过份的是每条数据里面都要给按钮相关的参数,实在是不好看。
     这两种实现方式各有优点和缺点,只能看哪里合适咯,呵呵。

结语:
    今天下午在和天猪讨论的时候,他告诉我可以拿renderer来做。
    说实话,我不喜欢上来就继承,之前也有写继承,老感觉有些说不出的毛病,呵呵。拿一些工具组合组合,小界面也能出来,做成个小函数代码也不多,改起来还方便。
    JE论坛Ext板块的置顶贴的牛人建议大家“建立自己的工具箱”,这个小界面就当做我的一个小工具咯。
    这篇小笔记就这么多,希望对你有点帮助。

转载于:https://www.cnblogs.com/holyes/archive/2012/06/26/d6e37e5af1a2d00122fe90edf66f4b91.html

这篇关于《仔仔细细分析Ext》 第N-2章 GridPanel的小难点 第一节 每条数据后面跟随几个操作按钮...的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/587391

相关文章

Nginx分布式部署流程分析

《Nginx分布式部署流程分析》文章介绍Nginx在分布式部署中的反向代理和负载均衡作用,用于分发请求、减轻服务器压力及解决session共享问题,涵盖配置方法、策略及Java项目应用,并提及分布式事... 目录分布式部署NginxJava中的代理代理分为正向代理和反向代理正向代理反向代理Nginx应用场景

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

Redis中的有序集合zset从使用到原理分析

《Redis中的有序集合zset从使用到原理分析》Redis有序集合(zset)是字符串与分值的有序映射,通过跳跃表和哈希表结合实现高效有序性管理,适用于排行榜、延迟队列等场景,其时间复杂度低,内存占... 目录开篇:排行榜背后的秘密一、zset的基本使用1.1 常用命令1.2 Java客户端示例二、zse

Redis中的AOF原理及分析

《Redis中的AOF原理及分析》Redis的AOF通过记录所有写操作命令实现持久化,支持always/everysec/no三种同步策略,重写机制优化文件体积,与RDB结合可平衡数据安全与恢复效率... 目录开篇:从日记本到AOF一、AOF的基本执行流程1. 命令执行与记录2. AOF重写机制二、AOF的

使用Java填充Word模板的操作指南

《使用Java填充Word模板的操作指南》本文介绍了Java填充Word模板的实现方法,包括文本、列表和复选框的填充,首先通过Word域功能设置模板变量,然后使用poi-tl、aspose-words... 目录前言一、设置word模板普通字段列表字段复选框二、代码1. 引入POM2. 模板放入项目3.代码

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

Python内存管理机制之垃圾回收与引用计数操作全过程

《Python内存管理机制之垃圾回收与引用计数操作全过程》SQLAlchemy是Python中最流行的ORM(对象关系映射)框架之一,它提供了高效且灵活的数据库操作方式,本文将介绍如何使用SQLAlc... 目录安装核心概念连接数据库定义数据模型创建数据库表基本CRUD操作创建数据读取数据更新数据删除数据查

Go语言中json操作的实现

《Go语言中json操作的实现》本文主要介绍了Go语言中的json操作的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录 一、jsOChina编程N 与 Go 类型对应关系️ 二、基本操作:编码与解码 三、结构体标签(Struc

MyBatis Plus大数据量查询慢原因分析及解决

《MyBatisPlus大数据量查询慢原因分析及解决》大数据量查询慢常因全表扫描、分页不当、索引缺失、内存占用高及ORM开销,优化措施包括分页查询、流式读取、SQL优化、批处理、多数据源、结果集二次... 目录大数据量查询慢的常见原因优化方案高级方案配置调优监控与诊断总结大数据量查询慢的常见原因MyBAT

分析 Java Stream 的 peek使用实践与副作用处理方案

《分析JavaStream的peek使用实践与副作用处理方案》StreamAPI的peek操作是中间操作,用于观察元素但不终止流,其副作用风险包括线程安全、顺序混乱及性能问题,合理使用场景有限... 目录一、peek 操作的本质:有状态的中间操作二、副作用的定义与风险场景1. 并行流下的线程安全问题2. 顺