sencha touch list 批量选择扩展(2013-7-29)

 扩展js代码

  1 /*
  2 *list多选扩展
  3 */
  4 Ext.define('ux.SimpleList', {
  5     alternateClassName: 'simpleList',
  6     extend: 'Ext.List',
  7     xtype: 'simpleList',
  8     config: {
  9         editCls: 'simpleList',
 10         //不加在长按时可能没反应
 11         onItemDisclosure: false,
 12         //是否在多选状态(不可更改)
 13         isSimple: false,
 14         //设置数据主键(可配置)
 15         ckId: 'id',
 16         //默认选择类型,用以应对多种选择情况
 17         defSimpleType: 0,
 18         //多选时弹出菜单栏(可配置)
 19         simpleToolBar: {
 20             //默认位置
 21             docked: 'bottom',
 22             //默认标题,用以应对多种选择情况
 23             defTitle: '删除',
 24             items: [{
 25                 xtype: 'button',
 26                 text: '全选',
 27                 align: 'left',
 28                 //标志是全选还是取消全选
 29                 isSimple: true,
 30                 listeners: {
 31                     tap: function (button) {
 32                         var list = button.up('list');
 33                         if (this.isSimple) {
 34                             this.setText('取消全选');
 35                             list.selectAll();
 36                         } else {
 37                             this.setText('全选');
 38                             list.deselectAll();
 39                         }
 40                         this.isSimple = !this.isSimple;
 41                     }
 42                 }
 43             },
 44             {
 45                 cls: 'moreButton',
 46                 xtype: 'button',
 47                 text: '取消',
 48                 align: 'right',
 49                 listeners: {
 50                     tap: function (button) {
 51                         var list = button.up('list');
 52                         //结束多选
 53                         list.endSimple(list);
 54                     }
 55                 }
 56             },
 57             {
 58                 cls: 'moreButton',
 59                 xtype: 'button',
 60                 text: '确定',
 61                 align: 'right',
 62                 listeners: {
 63                     tap: function (button) {
 64                         var list = button.up('list');
 65                         var items = list.getSelection();
 66                         //获取选中项
 67                         var ids = [];
 68                         for (var i = 0,
 69                         item; item = items[i]; i++) {
 70                             ids.push(item.data[list.config.ckId]);
 71                         }
 72                         if (ids.length>0) {
 73                             //触发选择成功事件list:list本身,items:被选中的行,ids:被选中key集合,list.config.simpleType:自定义配置状态
 74                             list.fireEvent('simpleSuccess', list, items, ids, list.config.simpleType);
 75                             //结束多选
 76                             list.endSimple(list);
 77                         }
 78                     }
 79                 }
 80             }]
 81         },
 82         listeners: {
 83             //监控是否在多选状态
 84             itemtap: function (list, index, target, record, e) {
 85                 //如果在多选状态停止后续事件的执行
 86                 if (this.config.isSimple) {
 87                     e.stopEvent();
 88                 }
 89             },
 90             //只要按键长按住就会触发,和按键是否离开没有关系
 91             itemtaphold: function (list, index, target, record, e) {
 92                 //开始多选
 93                 this.beginSimple();
 94             }
 95         }
 96     },
 97     //获取多选边栏
 98     getSimpleToolBar: function () {
 99         var simpleToolBar = Ext.create('Ext.TitleBar', this.config.simpleToolBar);
100         return simpleToolBar;
101     },
102     //进入多选状态
103     beginSimple: function (simpleType, title) {
104         if (!this.config.isSimple) {
105             //取消全选
106             this.deselectAll();
107             //进入多选模式
108             this.setMode('SIMPLE');
109             //添加css
110             this.addCls(this.config.editCls);
111             //显示OnItemDisclosure
112             this.setOnItemDisclosure(true);
113             //加入标记,以便在itemtap事件中进行判定
114             this.config.isSimple = true;
115             //应对多种选择需求
116             if (simpleType) {
117                 this.config.simpleType = simpleType;
118             } else {
119                 this.config.simpleType = this.config.defSimpleType;
120             }
121             //改变标题
122             if (title) {
123                 this.config.simpleToolBar.title = title;
124             } else {
125                 this.config.simpleToolBar.title = this.config.simpleToolBar.defTitle;
126             }
127             //添加多选边栏
128             this.add(this.getSimpleToolBar());
129         }
130     },
131     //结束多选模式
132     endSimple: function () {
133         var titlebar = this.down('titlebar');
134         if (titlebar) {
135             //移除多选边栏
136             titlebar.hide();
137             titlebar.destroy();
138             //取消全选
139             this.deselectAll();
140             //进入单选模式
141             this.setMode('SINGLE');
142             //移除css
143             this.removeCls(this.config.editCls);
144             //隐藏OnItemDisclosure
145             this.setOnItemDisclosure(false);
146             //加入标记,以便在itemtap事件中进行判定
147             this.config.isSimple = false;
148         }
149     },
150     //更新OnItemDisclosure需要
151     updateOnItemDisclosure: function (newConfig, oldConfig) {
152         if (oldConfig == null) {
153             return;
154         }
155         var items = this.listItems;
156         for (var i = 0,
157         ln = items.length; i < ln; i++) {
158             var dItem = items[i].getDisclosure();
159             newConfig === false ? dItem.hide() : dItem.show();
160         }
161     }
162 });

 

需要加入的css

1 .simpleList .x-list-disclosure {
2     -webkit-mask-size:100%;
3     -webkit-mask-image:url();
4     background-color:#ddd;
5     background-image:none;
6 }
7 .simpleList .x-item-selected .x-list-disclosure {
8     background-color:#006bb6;
9 }

使用示例js

 1 Ext.define('app.view.new.List', {
 2     alternateClassName: 'newList',
 3     extend: 'ux.SimpleList',
 4     requires: ['app.view.new.Info'],
 5     xtype: 'newList',
 6     config: {
 7         store: 'newList',
 8         cls: 'list', //自定义css
 9         itemTpl: new Ext.XTemplate('<div class="left w20"><div class="img" style="background: url({litpic}) no-repeat center;background-size: 100%;"></div></div>', '<div class="right w80"><div class="row">{title}</div><div class="row grayF">{time}</div></div>')
10     }
11 });

控制器js

 1 /*
 2 *新闻类
 3 */
 4 Ext.define('app.controller.New', {
 5     extend: 'Ext.app.Controller',
 6     config: {
 7         models: ['New'],
 8         stores: ['NewList'],
 9         views: ['new.List'],
10         refs: {
11             newList: 'newList'
12         },
13         control: {
14             //新闻列表
15             newList: {
16                 initialize: function (list) {
17                     MyUtil.showListByParams('newList', MyUtil.newParams, MyUtil.isNewLoad);
18                 },
19                 //itemtap事件被用来处理检测是否在编辑状态,所以这里使用itemsingletap而不能使用itemtap
20                 itemsingletap: function (list, index, target, record, e) {
21                     this.redirectTo('newInfo');
22                     MyUtil.showInfo(record, 'newInfo', 'NewInfo.ashx', 'body', {
23                         id: record.data.id
24                     });
25                 },
26                 //结束多选事件触发
27                 simpleSuccess: function (list, items, ids, type) {
28                     console.log(ids);
29                 }
30             }
31         }
32     }
33 });

效果:

  单击  

长按

确定后触发simpleSuccess事件,输出ids

 

 

posted @ 2013-07-18 15:19  魔狼再世  阅读(2663)  评论(9编辑  收藏  举报