Sencha Touch 自定义List的三种实现方案

来源:互联网 发布:淘宝开店的类目 编辑:程序博客网 时间:2024/05/01 16:59

在sencha touch的list里嵌入自己想要的控件,有多种选择方案。
其中一种是直接在itemTpl相应的地方加上html标签(如<button><input>)创建html控件。效果如下:

蛋疼了吧。。。风格不统一,而且要给按钮加事件也显得比较别扭。这个方案,当然还是有它的好处的,这是所有方案中效率最高的一个。

如果你使用的是图片按钮,自然也是可以很协调的。

如果我们想要用框架原有的按钮怎么办,这就是本篇文章的重点了。

第二种方案

先看效果

 

这个方案,要求你对Sencha Touch框架有一定程度的了解,当然,学习它也能让你对这个框架有更深一层的认识。

废话不说直接上代码。

复制代码
Ext.regModel('Example',{    fields:['id','text']});Ext.regStore('MyStore',{    model :'Example',    data:[        {id : '0', text : 'aaaa'},        {id : '1', text : 'bbbb'},        {id : '2', text : 'cccc'},        {id : '3', text : 'dddd'}    ]});var myApp = new Ext.Application({    //利用框架的Application类的构造函数构造一个应用    name: 'myApp',        //为这个应用指定名称    //useLoadMask: true,    launch: function () {            //这是程序的入口        var list = new Ext.List({            itemTpl : new Ext.XTemplate(                '<div>{text}</div>',                '<div style="float:right" id="button_{id}"></div>'),//这里的id让后面可以找到这个div并将按钮渲染到这个div中            store : 'MyStore',            isAfterrendered : false,    //添加一个变量,用于检测afterrender是否已经发生            listeners : {                afterrender : function() {            //afterrender事件只有list首次载入的时候才会触发。                    this.isAfterrendered = true;    //这个this是指list                    console.log('afterrender');        //请在调试状态下查看事件发生的顺序                },                update : function() {    //update事件在render(渲染)之前执行一次,渲染完毕                                        //后又会执行一次。以后在list内容发生改变时执行。                    console.log('update');                    if (this.isAfterrendered) {                        Ext.each(Ext.StoreMgr.lookup('MyStore').data.items,//对MyStore的每一条数据执行一次循环                            function(arrayItem, index) {                                new Ext.Button({                                    iconMask : true,                                    ui : 'plain',    //按钮背景透明                                    iconCls : 'delete',                                    renderTo : 'button_' + arrayItem.data.id                                });                            });                    }                }                    }        });                var panel = new Ext.Panel({            fullscreen : true, //设为全屏就会显示出来            items : list        });    }});
复制代码

该说的在注释里头都说了,就这样吧。

所有的控件都可以用过来,很好地保持了风格的统一,而且添加按钮事件也比较方便。

但是这样做因为需要额外的渲染,效率明显不如第一个方案。

第三个方案

这个是最近才想到的,在kitchen sink中,官方给出了三种list的示例,其中,第三种是这样的:

那么,只要我们将右侧的按钮图片换成我们自己需要的,便能够实现我们想要的效果了。

通过分析sencha touch的源码,我找到了相应的css代码,并提取出来,改成了自己的css,将其赋给自己的指定的list。

以下便是全部css的代码。

复制代码
.delBtnList .x-list-disclosure {  overflow: visible;  -webkit-mask: 0 0 url('');  -webkit-mask-size: 1.7em;  background-color: #0e6ee9;  background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #4f98f4), color-stop(50%, #1f7cf1), color-stop(51%, #0e6ee9), color-stop(100%, #0d63d1));  background-image: linear-gradient(#4f98f4, #1f7cf1 50%, #0e6ee9 51%, #0d63d1);  width: 1.7em;  height: 1.7em;}.delBtnList.x-list-indexed .x-list-disclosure {  margin-right: 1.3em;}.delBtnList .x-item-selected .x-list-disclosure {  background: #fff none;}
复制代码

但是这个方法这样做仍然存在一个问题:当小图标被点击时,仍然会触发itemtap事件,导致本不该执行的操作被执行。

继续查阅api文档,我发现了一个配置项:

preventSelectionOnDisclose True to prevent the item selection when the user taps a disclose icon. Defaults to true

这意味着,当我们点击了item的时候,会触发selectionchange事件,而点击小图标时不会。

我们可以通过这个特性,将点击item时要执行的操作写在selectionchange事件中,这样便能将两个操作隔开了。

后来又发现selectionchange取消选中时发生一次,选中时又发生一次。也就是说,点一次会执行两次,于是又加了段代码来fix它。

以下是成果。完成的效果,跟上面的第二种是类似的,但是因为利用的是系统原生的东西,bug少,不易出岔子。

复制代码
var list = new Ext.List({    cls : 'delBtnList',//为这个list的div添加一个类,我们通过这个来找到并更改item的右侧小图标。    onItemDisclosure : {//若配置该项,list每一项的右侧都会出现一个小图标。其他功能请查看api        handler : function(record, btn, index) {            alert('点击小按钮触发的事件');                }    },    listeners : {        selectionchange: function(selectionModel, records){            if (this.firstTime == true) {                this.firstTime = false;            }            else {                this.firstTime = true;                alert('点击item其他位置触发的事件');            }        },    },});
复制代码

OK,以上就是目前为止找到的三种方案。OVER。

0 0
原创粉丝点击