zoukankan      html  css  js  c++  java
  • sencha touch dataview 中添加 button 等复杂布局并添加监听事件

    config 中的属性默认都会自动生成   getter   setter  applier  updater 四个方法。

    applier 在调用  setter 时被调用, updater 在属性值被改变时调用

    Ext.application({
        launch: function () {
    
            // DataItem 相当与 list 中的一行 (row)
            // 对应 store 中的一条数据
            // 相当于 适配器
            Ext.define('MyListItem', {
                extend: 'Ext.dataview.component.DataItem',
                requires: ['Ext.Button'],
                xtype: 'mylistitem',
    
                config: {
                    // 水平布局
                    layout: 'hbox',
    
                    // 每行有一个 panel 和 两个 button
                    employeeName: true,
                    callButton: true,
                    smsButton: true,
    
                    defaults: {
                        // padding:10
                        margin: 5
                    },
                    // 当控件实例化时可调用一个方法初始化
                    // 在这里将 view 与 data 关联起来
                    dataMap: {
                        getEmployeeName: {
                            setHtml: 'name'
                        },
                        getCallButton: {
                            // setText: 'name'
                        },
                        getSmsButton: {
                            // setText: 'name'
                        }
                    }
                },
    
                // apply 时实例化该控件
                applyEmployeeName: function (config) {
                    return Ext.factory({flex: 1}, Ext.Panel, this.getEmployeeName());
                },
                applyCallButton: function (config) {
                    return Ext.factory({text: '打电话'}, Ext.Button, this.getCallButton());
                },
                applySmsButton: function (config) {
                    return Ext.factory({text: '发短信'}, Ext.Button, this.getSmsButton());
                },
    
                updateEmployeeName: function (newEmployeeName, oldEmployeeName) {
                    if (oldEmployeeName) {
                        this.remove(oldEmployeeName);
                    }
    
                    if (newEmployeeName) {
                        this.add(newEmployeeName);
                    }
                },
    
                updateCallButton: function (newcallButton, oldcallButton) {
                    if (oldcallButton) {
                        this.remove(oldcallButton);
                    }
    
                    if (newcallButton) {
                        // update 时绑定一个  tap  事件
                        newcallButton.on('tap', this.oncallButtonTap, this);
    
                        this.add(newcallButton);
                    }
                },
    
                updateSmsButton: function (newsmsButton, oldsmsButton) {
                    if (oldsmsButton) {
                        this.remove(oldsmsButton);
                    }
    
                    if (newsmsButton) {
                        newsmsButton.on('tap', this.onsmsButtonTap, this);
    
                        this.add(newsmsButton);
                    }
                },
    
                oncallButtonTap: function (button, e) {
                    var record = this.getRecord();
    
                    Ext.Msg.alert(
                        'Hello',
                        record.get('name')
                    );
                },
    
                onsmsButtonTap: function (button, e) {
                    var record = this.getRecord();
    
                    Ext.Msg.alert(
                        'Hello',
                        record.get('name')
                    );
                }
            });
    
            Ext.create('Ext.DataView', {
                fullscreen: true,
    
                store: {
                    fields: ['name'],
                    data: [
                        {name: 'Leslie'},
                        {name: 'Allan'},
                        {name: 'Caitlin'},
                        {name: 'Peter'}
                    ]
                },
                // 必须设置
                useComponents: true,
                // 指定每一行的布局
                defaultType: 'mylistitem'
            });
    
        }
    });
  • 相关阅读:
    关于分布式事务、两阶段提交协议、三阶提交协议(转)
    高并发下产生大量,随机,唯一的字符串,并输出到文件中
    地理空间距离计算优化_附近的人(转自美团技术博客)
    Web Deploy发布网站错误 检查授权和委派设置
    mssql查询所有上下级
    mssql语句递归查找所有下级
    挖洞技巧:任意账号密码重置
    MAC卸载java 12.0.2
    mac  安装brew时报错的问题及解决方式
    致远getshell
  • 原文地址:https://www.cnblogs.com/lesliefang/p/3659738.html
Copyright © 2011-2022 走看看