extjs 之 list checkbox

本文涉及的产品
可视分析地图(DataV-Atlas),3 个项目,100M 存储空间
数据可视化DataV,5个大屏 1个月
简介:

本例完成在一个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,如需转载请自行联系原作者

相关实践学习
Github实时数据分析与可视化
基于Github Archive公开数据集,将项目、行为等20+种事件类型数据实时采集至Hologres进行分析,并搭建可视化大屏。
阿里云实时数仓实战 - 项目介绍及架构设计
课程简介 1)学习搭建一个数据仓库的过程,理解数据在整个数仓架构的从采集、存储、计算、输出、展示的整个业务流程。 2)整个数仓体系完全搭建在阿里云架构上,理解并学会运用各个服务组件,了解各个组件之间如何配合联动。 3&nbsp;)前置知识要求 &nbsp; 课程大纲 第一章&nbsp;了解数据仓库概念 初步了解数据仓库是干什么的 第二章&nbsp;按照企业开发的标准去搭建一个数据仓库 数据仓库的需求是什么 架构 怎么选型怎么购买服务器 第三章&nbsp;数据生成模块 用户形成数据的一个准备 按照企业的标准,准备了十一张用户行为表 方便使用 第四章&nbsp;采集模块的搭建 购买阿里云服务器 安装 JDK 安装 Flume 第五章&nbsp;用户行为数据仓库 严格按照企业的标准开发 第六章&nbsp;搭建业务数仓理论基础和对表的分类同步 第七章&nbsp;业务数仓的搭建&nbsp; 业务行为数仓效果图&nbsp;&nbsp;
相关文章
HTML中<button />和<input type=“button“/>的区别
HTML中<button />和<input type=“button“/>的区别
83 0
input[type="radio"]自定义样式
input为radio时,虽然会有默认选中的样式,但是并不符合大多数项目的需求,我们的目标是可以随心所欲自定义它的样式。怎么做呢?其实很简单,只要抓住3点。分别是1.label 2.隐藏自带样式 3.绘制我们的样式。
1182 0
|
JavaScript 搜索推荐
jQuery的attr方法处理checkbox的问题
现象 使用了 jQuery 1.10 的版本,想实现 checkbox 的全部选中和全部取消选中,使用了 attr 的方法,如下: $(elem).attr(“checked”) 测试过程中发现,第一次从未选中状态变为选中,再从选中变为未选中,是可以的。
1070 0