extjs 之 list checkbox

简介:

本例完成在一个listview中放入checkbox列表,设计知识:Ext.XTemplate和Ext.DataView
 
源码如下

 


 
 
  1. function casereport_init() {  
  2.     function oncheck(str) {  
  3.         if (Ext.fly('box' + str).hasClass('checked')) {  
  4.             Ext.fly('box' + str).removeClass('checked');  
  5.             document.getElementById('check' + str).checked = false;  
  6.         } else {  
  7.             Ext.fly('box' + str).addClass('checked');  
  8.             document.getElementById('check' + str).checked = true;  
  9.         }  
  10.     }  
  11.  
  12.     var proxyData = new Ext.data.HttpProxy({  
  13.         url : 'GetCaseReportType' 
  14.     });  
  15.     var strData = new Ext.data.JsonStore({  
  16.         proxy : proxyData,  
  17.         root : 'data',  
  18.         fields : [ 'id''message' ]  
  19.     });  
  20.  
  21.     var tplData = new Ext.XTemplate('<tpl for=".">',  
  22.             '<div class="databox" id="box{id}" onclick="oncheck({id})">',  
  23.             '<input type="checkbox" id="check{id}" value="c{id}"> ',  
  24.             '&nbsp;{message}</div>''</tpl>''<div class="x-clear"></div>');  
  25.  
  26.     var dataV = new Ext.DataView({  
  27.         autoScroll : true,  
  28.         store : strData,  
  29.         tpl : tplData,  
  30.         autoHeight : true,  
  31.         height : 265,  
  32.         multiSelect : true,  
  33.         itemSelector : 'div.thumb-wrap',  
  34.         emptyText : 'No data to display',  
  35.         loadingText : 'Please Wait...'//,  
  36.         //style : 'border:1px solid #99BBE8;background:#fff;'  
  37.     });  
  38.  
  39.     function checkvalue() {  
  40.         var obj = Ext.select('input[type=checkbox]').elements;  
  41.         var i = 0;  
  42.         var cb = '';  
  43.         var total = 0;  
  44.         for (i = 0; i < obj.length; i++) {  
  45.             if (obj[i].checked) {  
  46.                 cb = cb + ' ' + obj[i].value;  
  47.                 total++;  
  48.             }  
  49.         }  
  50.         Ext.MessageBox.alert('Checked''You clicked ' + total  
  51.                 + ' checkbox, they value are ' + cb);  
  52.     }  
  53.     var gen_button = new Ext.Toolbar.Button({  
  54.         xtype:'button',  
  55.         text:'生成报表',      
  56.         handler: function(){  
  57.             checkvalue();  
  58.         }  
  59.     });  
  60.       
  61.  
  62.     var outer_center_west = new Ext.Panel({  
  63.         region : 'west',  
  64.         width : Glb.outer_center.getWidth() * 0.25,  
  65.         height : Glb.outer_center.getHeight(),  
  66.         border : true,  
  67.         split : true,  
  68.         tbar:[gen_button],  
  69.         bodyStyle : 'padding:5px;',  
  70.         autoScroll : true,  
  71.         collapsible : true 
  72.     });  
  73.     outer_center_west.show();  
  74.  
  75.     var outer_center_center = new Ext.Panel({  
  76.         region : 'center',  
  77.         width : Glb.outer_center.getWidth() * 0.7,  
  78.         height : Glb.outer_center.getHeight(),  
  79.         border : true,  
  80.         autoScroll : true,  
  81.         bodyStyle : 'padding:5px;',  
  82.         split : true 
  83.     });  
  84.     outer_center_center.show();  
  85.  
  86.     outer_center_west.add(dataV);  
  87.  
  88.     var caseReportPanel = new Ext.Panel({  
  89.         id : 'border-panel',  
  90.         layout : 'border',  
  91.         width : Glb.outer_center.getWidth(),  
  92.         height : Glb.outer_center.getHeight(),  
  93.         border : true,  
  94.         items : [ outer_center_west, outer_center_center ]  
  95.     });  
  96.     strData.load();  
  97.     Glb.outer_center.add(caseReportPanel);  
  98.     Glb.outer_center.show();  
  99.     Glb.outer_center.doLayout();  
  100.  

效果图如下:

 

 


本文转自elbertchen 51CTO博客,原文链接:http://blog.51cto.com/linkyou/751961,如需转载请自行联系原作者

相关实践学习
基于Hologres轻量实时的高性能OLAP分析
本教程基于GitHub Archive公开数据集,通过DataWorks将GitHub中的项⽬、行为等20多种事件类型数据实时采集至Hologres进行分析,同时使用DataV内置模板,快速搭建实时可视化数据大屏,从开发者、项⽬、编程语⾔等多个维度了解GitHub实时数据变化情况。
阿里云实时数仓实战 - 用户行为数仓搭建
课程简介 1)学习搭建一个数据仓库的过程,理解数据在整个数仓架构的从采集、存储、计算、输出、展示的整个业务流程。 2)整个数仓体系完全搭建在阿里云架构上,理解并学会运用各个服务组件,了解各个组件之间如何配合联动。 3&nbsp;)前置知识要求:熟练掌握 SQL 语法熟悉 Linux 命令,对 Hadoop 大数据体系有一定的了解 &nbsp; 课程大纲 第一章&nbsp;了解数据仓库概念 初步了解数据仓库是干什么的 第二章&nbsp;按照企业开发的标准去搭建一个数据仓库 数据仓库的需求是什么 架构 怎么选型怎么购买服务器 第三章&nbsp;数据生成模块 用户形成数据的一个准备 按照企业的标准,准备了十一张用户行为表 方便使用 第四章&nbsp;采集模块的搭建 购买阿里云服务器 安装 JDK 安装 Flume 第五章&nbsp;用户行为数据仓库 严格按照企业的标准开发 第六章&nbsp;搭建业务数仓理论基础和对表的分类同步 第七章&nbsp;业务数仓的搭建&nbsp; 业务行为数仓效果图&nbsp;&nbsp;
相关文章
|
4天前
|
搜索推荐 编译器 Linux
一个可用于企业开发及通用跨平台的Makefile文件
一款适用于企业级开发的通用跨平台Makefile,支持C/C++混合编译、多目标输出(可执行文件、静态/动态库)、Release/Debug版本管理。配置简洁,仅需修改带`MF_CONFIGURE_`前缀的变量,支持脚本化配置与子Makefile管理,具备完善日志、错误提示和跨平台兼容性,附详细文档与示例,便于学习与集成。
293 116
|
19天前
|
域名解析 人工智能
【实操攻略】手把手教学,免费领取.CN域名
即日起至2025年12月31日,购买万小智AI建站或云·企业官网,每单可免费领1个.CN域名首年!跟我了解领取攻略吧~
|
7天前
|
数据采集 人工智能 自然语言处理
Meta SAM3开源:让图像分割,听懂你的话
Meta发布并开源SAM 3,首个支持文本或视觉提示的统一图像视频分割模型,可精准分割“红色条纹伞”等开放词汇概念,覆盖400万独特概念,性能达人类水平75%–80%,推动视觉分割新突破。
451 44
Meta SAM3开源:让图像分割,听懂你的话
|
13天前
|
安全 Java Android开发
深度解析 Android 崩溃捕获原理及从崩溃到归因的闭环实践
崩溃堆栈全是 a.b.c?Native 错误查不到行号?本文详解 Android 崩溃采集全链路原理,教你如何把“天书”变“说明书”。RUM SDK 已支持一键接入。
684 222
|
1天前
|
Windows
dll错误修复 ,可指定下载dll,regsvr32等
dll错误修复 ,可指定下载dll,regsvr32等
133 95
|
11天前
|
人工智能 移动开发 自然语言处理
2025最新HTML静态网页制作工具推荐:10款免费在线生成器小白也能5分钟上手
晓猛团队精选2025年10款真正免费、无需编程的在线HTML建站工具,涵盖AI生成、拖拽编辑、设计稿转代码等多种类型,均支持浏览器直接使用、快速出图与文件导出,特别适合零基础用户快速搭建个人网站、落地页或企业官网。
1677 158
|
存储 人工智能 监控
从代码生成到自主决策:打造一个Coding驱动的“自我编程”Agent
本文介绍了一种基于LLM的“自我编程”Agent系统,通过代码驱动实现复杂逻辑。该Agent以Python为执行引擎,结合Py4j实现Java与Python交互,支持多工具调用、记忆分层与上下文工程,具备感知、认知、表达、自我评估等能力模块,目标是打造可进化的“1.5线”智能助手。
925 61