ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

javascript – 如何在extjs中单击按钮后打开窗口

2019-07-16 19:36:36  阅读:316  来源: 互联网

标签:javascript window viewport extjs designer


我正在使用extjs设计师2.它工作正常,我设计了一个视口.它会创建一些视图文件.第一个是myviewport.js:

Ext.define('MyApp.view.MyViewport', {
    extend: 'Ext.container.Viewport',

    layout: {
        type: 'border'
    },

    initComponent: function () {
        var me = this;

        Ext.applyIf(me, {
            items: [{
                xtype: 'tabpanel',
                activeTab: 1,
                region: 'center',
                items: [{
                    xtype: 'panel',
                    title: 'SIM usage'
                }, {
                    xtype: 'gridpanel',
                    title: 'Reports',
                    forceFit: true,
                    store: 'ReportsStore',
                    columns: [{
                        xtype: 'gridcolumn',
                        dataIndex: 'Name',
                        text: 'Name'
                    }, {
                        xtype: 'gridcolumn',
                        dataIndex: 'Type',
                        text: 'Type'
                    }, {
                        xtype: 'gridcolumn',
                        dataIndex: 'Description',
                        text: 'Description'
                    }, {
                        xtype: 'actioncolumn',
                        items: [{
                            handler: function (view, rowIndex, colIndex, item, e) {
                                alert(view);
                            },
                            altText: 'Run report',
                            iconCls: 'runReport'
                        }]
                    }],
                    viewConfig: {

                    },
                    dockedItems: [{
                        xtype: 'toolbar',
                        dock: 'top',
                        items: [{
                            xtype: 'tbfill'
                        }, {
                            xtype: 'button',
                            iconCls: 'addReport',
                            text: 'Add report',
                            listeners: {
                                click: {
                                    fn: me.onButtonClick,
                                    scope: me
                                }
                            }
                        }]
                    }]
                }, {
                    xtype: 'panel',
                    title: 'Pyshical SIM cards'
                }, {
                    xtype: 'panel',
                    title: 'Virtual SIM cards'
                }, {
                    xtype: 'form',
                    layout: {
                        type: 'absolute'
                    },
                    bodyPadding: 10,
                    title: 'Config',
                    items: [{
                        xtype: 'numberfield',
                        id: 'IP1',
                        width: 220,
                        fieldLabel: 'Server IP',
                        labelWidth: 150
                    }, {
                        xtype: 'numberfield',
                        id: 'IP2',
                        width: 80,
                        fieldLabel: '.',
                        labelPad: 0,
                        labelSeparator: ' ',
                        labelWidth: 10,
                        x: 240,
                        y: 10
                    }, {
                        xtype: 'numberfield',
                        id: 'IP3',
                        width: 80,
                        fieldLabel: '.',
                        labelPad: 0,
                        labelSeparator: ' ',
                        labelWidth: 10,
                        x: 330,
                        y: 10
                    }, {
                        xtype: 'numberfield',
                        id: 'IP4',
                        width: 80,
                        fieldLabel: '.',
                        labelPad: 0,
                        labelSeparator: ' ',
                        labelWidth: 10,
                        x: 420,
                        y: 10
                    }, {
                        xtype: 'textfield',
                        id: 'username',
                        fieldLabel: 'username',
                        labelWidth: 150,
                        anchor: '100%',
                        x: 10,
                        y: 40
                    }, {
                        xtype: 'textfield',
                        id: 'password',
                        inputType: 'password',
                        fieldLabel: 'password',
                        labelWidth: 150,
                        anchor: '100%',
                        x: 10,
                        y: 70
                    }, {
                        xtype: 'textareafield',
                        id: 'emails',
                        fieldLabel: 'Alert emails',
                        labelWidth: 150,
                        anchor: '100%',
                        x: 10,
                        y: 100
                    }, {
                        xtype: 'textfield',
                        id: 'smtp',
                        fieldLabel: 'SMTP',
                        labelWidth: 150,
                        anchor: '100%',
                        x: 10,
                        y: 170
                    }, {
                        xtype: 'textfield',
                        id: 'smtpCredentials',
                        fieldLabel: 'SMTP Server credentials',
                        labelWidth: 150,
                        anchor: '100%',
                        x: 10,
                        y: 200
                    }, {
                        xtype: 'button',
                        height: 30,
                        width: 90,
                        text: 'Restore',
                        x: 170,
                        y: 230
                    }, {
                        xtype: 'button',
                        height: 30,
                        width: 90,
                        text: 'Save config',
                        x: 270,
                        y: 230
                    }]
                }]
            }]
        });

        me.callParent(arguments);
    },

    onButtonClick: function (button, e, options) {}
});

随着

onButtonClick: function(button, e, options) { }

我想打开一个窗口.但我不知道该怎么做.我已经创建了一个窗口,它存储在mywindow.js文件中:

Ext.define('MyApp.view.MyWindow', {
    extend: 'Ext.window.Window',

    height: 334,
    width: 540,
    layout: {
        type: 'border'
    },
    title: 'Run report',

    initComponent: function () {
        var me = this;

        Ext.applyIf(me, {
            items: [{
                xtype: 'form',
                bodyPadding: 10,
                region: 'center'
            }]
        });

        me.callParent(arguments);
    }
});

现在我在onbuttonclick事件中放了什么?

解决方法:

添加

Ext.create('MyApp.view.MyWindow').show();

你的按钮处理程序应该做的伎俩.

标签:javascript,window,viewport,extjs,designer
来源: https://codeday.me/bug/20190716/1481187.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有