1.        用Sencha Cmd生成应用程序模版

sencha -sdk /path/to/ExtSDK generate app -classic TutorialApp./TutorialApp

2.        创建Login View组件

在./TutorialApp的“app/view/”目录下,有缺省的main目录,这个目录包括了文件Main.jsMainController.js,和 MainModel.js。

在“app/view/”目录下创建一个目录“login”,在“login”目录下,新建两个文件
Login.js和LoginController.js。

3.        从“{appRoot}/app.js”中移除mainView。

4.        创建Login窗体。文件 “{appRoot}/app/view/login/Login.js” 的内容例如以下:

Ext.define('TutorialApp.view.login.Login',{

extend: 'Ext.window.Window',

xtype: 'login',

requires: [

'TutorialApp.view.login.LoginController',

'Ext.form.Panel'

],

controller: 'login',

bodyPadding: 10,

title: 'Login Window',

closable: false,

autoShow: true,

items: {

xtype: 'form',

reference: 'form',

items: [{

xtype: 'textfield',

name: 'username',

fieldLabel: 'Username',

allowBlank: false

}, {

xtype: 'textfield',

name: 'password',

inputType: 'password',

fieldLabel: 'Password',

allowBlank: false

}, {

xtype: 'displayfield',

hideEmptyLabel: false,

value: 'Enter any non-blank password'

}],

buttons: [{

text: 'Login',

formBind: true,

listeners: {

click: 'onLoginClick'

}

}]

}

});

5.        添加Login逻辑,“{appRoot}/app/view/login/LoginController.js ”文件的内容例如以下:

Ext.define('TutorialApp.view.login.LoginController',{

extend: 'Ext.app.ViewController',

alias: 'controller.login',

onLoginClick: function() {

// This would be the ideal location to verify the user's credentials via

// a server-side lookup. We'll just move forward for the sake of thisexample.

// Set the localStorage value to true

localStorage.setItem("TutorialLoggedIn", true);

// Remove Login Window

this.getView().destroy();

// Add the main view to the viewport

Ext.create({

xtype: 'app-main'

});

}

});

6.        在Application.js中添加Launch逻辑。Application.js文件例如以下:

Ext.define('TutorialApp.Application', {

extend: 'Ext.app.Application',

name: 'TutorialApp',

stores: [

// TODO: add global / shared stores here

],

views: [

'TutorialApp.view.login.Login',

'TutorialApp.view.main.Main'

],

launch: function () {

// It's important to note that this type of application could use

// any type of storage, i.e., Cookies,LocalStorage, etc.

var loggedIn;

// Check to see the current value of the localStorage key

loggedIn = localStorage.getItem("TutorialLoggedIn");

// This ternary operator determines the value of the TutorialLoggedInkey.

// If TutorialLoggedIn isn't true, we display the login window,

// otherwise, we display the main view

Ext.create({

xtype: loggedIn ? 'app-main' : 'login'

});

},

onAppUpdate: function () {

Ext.Msg.confirm('Application Update', 'This application has an update,reload?

',

function (choice) {

if (choice === 'yes') {

window.location.reload();

}

}

);

}

});

7.        添加Viewport Plugin和Logoutbutton,“ {appRoot}/app/view/main/Main.js”文件例如以下:

Ext.define('TutorialApp.view.main.Main', {

extend: 'Ext.tab.Panel',

xtype: 'app-main',

requires: [

'Ext.plugin.Viewport',

'Ext.window.MessageBox',

'TutorialApp.view.main.MainController',

'TutorialApp.view.main.MainModel',

'TutorialApp.view.main.List'

],

controller: 'main',

viewModel: 'main',

plugins: 'viewport',

ui: 'navigation',

tabBarHeaderPosition: 1,

titleRotation: 0,

tabRotation: 0,

header: {

layout: {

align: 'stretchmax'

},

title: {

bind: {

text: '{name}'

},

flex: 0

},

iconCls: 'fa-th-list',

items: [{

xtype: 'button',

text: 'Logout',

margin: '10 0',

handler: 'onClickButton'

}]

},

tabBar: {

flex: 1,

layout: {

align: 'stretch',

overflowHandler: 'none'

}

},

responsiveConfig: {

tall: {

headerPosition: 'top'

},

wide: {

headerPosition: 'left'

}

},

defaults: {

bodyPadding: 20,

tabConfig: {

plugins: 'responsive',

responsiveConfig: {

wide: {

iconAlign: 'left',

textAlign: 'left'

},

tall: {

iconAlign: 'top',

textAlign: 'center',

width: 120

}

}

}

},

items: [{

title: 'Home',

iconCls: 'fa-home',

// The following grid shares a store with the classic version's grid aswell!

items: [{

xtype: 'mainlist'

}]

}, {

title: 'Users',

iconCls: 'fa-user',

bind: {

html: '{loremIpsum}'

}

},{

title: 'Groups',

iconCls: 'fa-users',

bind: {

html: '{loremIpsum}'

}

}, {

title: 'Settings',

iconCls: 'fa-cog',

bind: {

html: '{loremIpsum}'

}

}]

});

8.        添加main逻辑。 “{appRoot}/app/view/main/MainController.js”文件例如以下:

Ext.define('TutorialApp.view.main.MainController',{

extend: 'Ext.app.ViewController',

alias: 'controller.main',

onItemSelected: function (sender, record) {

Ext.Msg.confirm('Confirm', 'Are you sure?', 'onConfirm', this);

},

onConfirm: function (choice) {

if (choice === 'yes') {

//

}

},

onClickButton: function () {

// Remove the localStorage key/value

localStorage.removeItem('TutorialLoggedIn');

// Remove Main View

this.getView().destroy();

// Add the Login Window

Ext.create({

xtype: 'login'

});

}

});

EXT-JS 6演示样例程序-Login演示样例程序的更多相关文章

  1. 将Ext JS 6应用程序导入Web项目

    由于Ext JS 6包含了Sencha Touch,因而在应用程序结构有了些改变,Ext JS 5的方法已经不适用于新版本了.经过研究,发现6导入Web项目要比5简单. 下面来说说导入的过程. 使用S ...

  2. 【翻译】探究Ext JS 5和Sencha Touch的布局系统

    原文:Exploring the Layout System in Ext JS 5 and Sencha Touch 布局系统是Sencha框架中最强大和最有特色的一个部分. 布局要处理应用程序中每 ...

  3. 【翻译】Sencha Ext JS 5公布

    原文:Announcing Sencha Ext JS 5 简单介绍 我代表Sencha和整个Ext JS团队,非常自豪的宣布,在今天,Sencha Ext JS 5公布了.Ext JS 5已经迈出了 ...

  4. 【翻译】如何创建Ext JS暗黑主题之一

    原文:How to Create a Dark Ext JS Theme– Part 1 概述 我是不是都要演示我的Spotifinder Ext JS应用程序.它是一个很酷的应用程序,可连接到Las ...

  5. Ext JS 4 新特性2:配置项属性(config)之二

    Ext JS 4 新特征2:配置项属性config之二 ☞ Config(自动的setters和getters) Ext JS 4介绍了config声明方式,在Ext JS 中也有几个例子:在运行程序 ...

  6. 【翻译】了解Ext JS 5的小部件

    原文:Understanding Widgets in Ext JS 5 在Ext JS 5,引入了新的"widgetcolumn",支持在网格的单元格中放置组件.同时,还在Ext ...

  7. 【翻译】Sencha Ext JS 5发布

    原文:Announcing Sencha Ext JS 5 简介 我代表Sencha和整个Ext JS团队,很自豪的宣布,在今天,Sencha Ext JS 5发布了.Ext JS 5已经迈出了一大步 ...

  8. 【翻译】对于Ext JS 5,你准备好了吗?

    原文:Are You Ready for Ext JS 5? Ext JS 5:准备升级 对于Ext JS 5加入Sencha的大家庭,我们感到非常高兴!作为一个主要版本,在Ext JS 5引入了一堆 ...

  9. 【翻译】Ext JS 5的委托事件和手势

    原文:Delegated Events and Gestures in Ext JS 5 简介 Ext JS在5之前的版本,被设计为专用于传统鼠标输入的桌面设备使用.而从5开始,添加了对触屏输入的支持 ...

  10. 使用Ext JS,不要使用页面做组件重用,尽量不要做页面跳转

    今天,有人请教我处理办法,问题是: 一个Grid,选择某条记录后,单击编辑后,弹出编辑窗口(带编辑表单),编辑完成后单击保存按钮保存表单,并关闭窗口,刷新Grid. 这,本来是很简单的,但囿于开发人员 ...

随机推荐

  1. easyui 属性集合

    easyUI属性汇总 属性分为CSS片段和JS片段. CSS类定义:1.div easyui-window 生成一个window窗口样式. 属性如下: 1)modal:是否生成模态窗口.true[是] ...

  2. iOS11 获取手机已安装应用列表

    在iOS 11 以前我们可以使用LSApplicationWorkspace来获取手机上已安装的应用列表 iOS 11 上获取所有已安装应用接口被禁,但可以根据BundleId检查App是否存在 - ...

  3. 典型案例收集-使用OpenVPN连通多个机房内网(转)(静态路由)

    说明: 1.这篇文章主要是使用静态路由表实现的多个机房通过VPN连接后的子网机房互通. 2.OpenVPN使用的是桥接模式(server-bridge和dev tap),这个是关键点,只有这样设置才可 ...

  4. linux ntfs模块

    步骤: 1.在/usr/src/linux-2.4.18-3/configs/目录下 找适合自己机器的内核配置文件.我用的kernel-2.4.18-x86_64.config,把它拷贝到/usr/s ...

  5. EntityFramework:EF Migrations Command Reference

    Entity Framework Migrations are handled from the package manager console in Visual Studio. The usage ...

  6. JDK JRE区别

    JDK里面的工具也是用JAVA编写的,它们本身运行的时候也需要一套JRE,如C:/Program Files/Java/jdk1.5.x/目录下的JRE.而C:/Program Files/Java/ ...

  7. 解决HUE报错MultipleObjectsReturned: get() returned more than one Document2 -- it returned 2!

    表现:界面上报错:,刚登陆进去就能看到,点击执行也会出现.日志里报: Traceback (most recent call last): File "/home/work/hue-3.10 ...

  8. 1503162139-ny-分数拆分

    分数拆分 时间限制:3000 ms  |  内存限制:65535 KB 难度:1 描写叙述 如今输入一个正整数k,找到全部的正整数x>=y,使得1/k=1/x+1/y. 输入 第一行输入一个整数 ...

  9. JOIN与EXISTS(子查询)的效率研究

    使用MySQL提供的Sample数据库Sakila 现将profiling打开,用来一会查看sql执行时间 set profiling=1; exists 子查询与 join联接效率的对比,功能:查看 ...

  10. ECMAScript新特性【一】--Object.create

    Object.create(prototype, descriptors) :创建一个具有指定原型且可选择性地包含指定属性的对象 参数: prototype 必需.  要用作原型的对象. 可以为 nu ...