本文地址:http://blog.csdn.net/sushengmiyan/article/details/38815923

实例代码下载地址: http://download.csdn.net/detail/sushengmiyan/7817549

本文作者:sushengmiyan

------------------------------------------------------------------------------------------------------------------------------------

暂时完成效果图如下:

1.登录界面

输入任意用户名与密码(暂时没有设置登录验证等,后期添加),点击用户登录进入主页面

在左下角,显示了你刚才输入的用户名,实现了数据的传输。

代码模块展示如下:

app.js

/*
* This file is generated and updated by Sencha Cmd. You can edit this file as
* needed for your application, but these edits will have to be merged by
* Sencha Cmd when upgrading.
*/
Ext.application({
name: 'oaSystem', extend: 'oaSystem.Application', //autoCreateViewport: 'oaSystem.view.main.Main', //-------------------------------------------------------------------------
// Most customizations should be made to oaSystem.Application. If you need to
// customize this file, doing so below this section reduces the likelihood
// of merge conflicts when upgrading to new versions of Sencha Cmd.
//------------------------------------------------------------------------- });

application.js

/**
* The main application class. An instance of this class is created by app.js when it calls
* Ext.application(). This is the ideal place to handle application launch and initialization
* details.
*/
Ext.define('oaSystem.Application', {
extend: 'Ext.app.Application', name: 'oaSystem',
uses:['oaSystem.SimData', 'Ext.ux.ajax.*'],
views: [
// TODO: add views here
], controllers: [
'Root'
// TODO: add controllers here
], stores: [
// TODO: add stores here
], launch: function () {
// TODO - Launch the application
//服务器傀儡,模拟真实世界中服务器交换
//oaSystem.SimData.init();
//console.log('launch begin');
//this.callParent()
Ext.ux.ajax.SimManager.init().register({
'/authenticate':
{
type: 'json',
data: function(ctx){
return Ext.apply({}, true);
}
}
});
}
});

login.js

Ext.define(
'oaSystem.view.login.Login',
{
requires:['oaSystem.view.login.LoginController'],
extend: 'Ext.window.Window',
controller: 'login',
closable: false,
resizable : false,
modal: true,
//draggable: false,
autoShow: true,
title: '用户登录---OA办公系统',
glyph: 'xf007@FontAwesome',
items:[{
xtype:'form',//父窗体
reference: 'form',
bodyPadding: 20,
items:[{
xtype: 'textfield',
name: 'username',
labelWidth: 50,
fieldLabel: '用户名',
allowBlank: false,
emptyText: '用户名或邮箱地址'
},{
xtype: 'textfield',
name: 'password',
labelWidth: 50,
inputType: 'password',
fieldLabel: '密 码',
allowBlank: false,
emptyText: '请输入您的密码'
}]
}],
buttons: [{
name: 'registbutton',
text: '用户注册',
glyph: 'xf118@FontAwesome'
},{
name: 'loginbutton',
text: '用户登录',
glyph: 'xf110@FontAwesome',
region: 'center',
listeners:{
click: 'onLoginbtnClick'//单击事件 调用LoginConroller.js中的onLoginbtnClick函数
}
}]
}
);

logincontroller.js

Ext.define(
'oaSystem.view.login.LoginController',
{
extend: 'Ext.app.ViewController',
alias: 'controller.login', //用户登录按钮事件处理
onLoginbtnClick: function(){
var form = this.lookupReference('form');
if (form.isValid()) {
this.login({
data: form.getValues(),
scope: this,
success: 'onLoginSuccess',
failure: 'onLoginFailure'
})}
}, onLoginFailure: function() {
// Do something
Ext.getBody().unmask();
}, onLoginSuccess: function(logname, logpass) {
console.log('登录成功,用户名: ' + logname);
console.log('登录成功,密 码: ' + logpass);
this.fireViewEvent('login', logname);
//var org = this.lookupReference('organization').getSelectedRecord();
// this.fireViewEvent('login', this.getView(), user, org, this.loginManager);
}, login: function(options) {
Ext.Ajax.request({
url: '/authenticate',
method: 'GET',
params: options.data,
scope: this,
callback: this.onLoginReturn,
original: options
});
},
/**
applyModel: function(model) {
return model && Ext.data.schema.Schema.lookupEntity(model);
},
*/
onLoginReturn: function(options, success, response) {
options = options.original;
//var session = this.getSession(),
// resultSet; if (success) {
console.log('log in success');
/**
resultSet = this.getModel().getProxy().getReader().read(response, {
recordCreator: session ? session.recordCreator : null
}); if (resultSet.getSuccess()) {
Ext.callback(options.success, options.scope, [resultSet.getRecords()[0]]);
/*/
console.log(response);
Ext.callback(options.success, options.scope, [options.data.username, options.data.password]);
return;
//}
} //Ext.callback(options.failure, options.scope, [response, resultSet]);
}
}
);

main.js

Ext.define(
'oaSystem.view.main.Main',
{
extend: 'Ext.container.Viewport',
uses:['oaSystem.view.main.region.Top', 'oaSystem.view.main.region.Bottom'],
layout: { type: 'border' },
viewModel: { type: 'main' },
items: [{
xtype: 'maintop',
region: 'north'
},
{
xtype: 'mainbottom',
region: 'south',
bind: '你好,{currentUser}'
},
{
xtype: 'panel'
}], initComponent: function(){
//设置图标文件,设置后可以使用glyph属性
Ext.setGlyphFontFamily('FontAwesome');
this.callParent();
}
} );

root.js

/**
* The main application controller. This is a good place to handle things like routes.
* 这是主程序的控制器,这里适合做类似路由转发这样的事情
*/
Ext.define('oaSystem.controller.Root',
{
extend: 'Ext.app.Controller',
uses: ['oaSystem.view.login.Login','oaSystem.view.main.Main'],
/**
* 初始化事件
*/
onLaunch: function () {
var session = this.session = new Ext.data.Session();
if (Ext.isIE8) {
Ext.Msg.alert('亲,本例子不支持IE8哟');
return;
}; this.login = new oaSystem.view.login.Login({
session: session,
listeners: {
scope: this,
login: 'onLogin'
}});
},
/**
* logincontroller 的 "login" 事件回调.
* @param user
* @param loginManager
*/
onLogin: function (username, loginController) {
this.login.destroy();
this.user = username;
console.log('username: ' + username);
this.showUI();
}, showUI: function(){ console.log('show ui started');
//显示主界面
this.viewport = new oaSystem.view.main.Main(
{ //用户信息传入视图
viewModel: {
data:
{
currentUser: this.user
}
}
}
);
}
});

实例代码打包下载地址:http://download.csdn.net/detail/sushengmiyan/7817549

使用方法:

1.第一步:使用sencha cmd 创建项目 名称需要注意 输入为oaSystem

   我使用的命令如下:sencha -sdk  E:\openSrc\ext-5.0.0 generate app oaSystem E:\workspaces\myeclipse2014\csdn

如果不太清楚sencha cmd的命令参数,建议先阅读 http://blog.csdn.net/sushengmiyan/article/details/38313537



2.第二步:使用sencha app build 命令构建应用程序,使用sencha web start 测试是否成功。

建议先阅读:http://blog.csdn.net/sushengmiyan/article/details/38331347

3.将刚才新建目录下的app文件夹全部删除,将下载的压缩文件解压缩,直接解压缩到项目目录即可,重新build运行。

[ExtJS5学习笔记]第十一节 Extjs5MVVM模式下系统登录实例的更多相关文章

  1. [ExtJS5学习笔记]第二十一节 Extjs5中使用config配置给ext.widget或者create方法传递参数

    本文地址:http://blog.csdn.net/sushengmiyan/article/details/39252805 官方例子:http://docs.sencha.com/extjs/5. ...

  2. [ExtJS5学习笔记]第六节 Extjs的类系统Class System命名规则及定义和调试

    本文地址: http://blog.csdn.net/sushengmiyan/article/details/38479079 本文作者:sushengmiyan ----------------- ...

  3. 苹果手机Safari无痕浏览模式下系统登录成功但是页面不跳转

    昨天下午,测试提了一个bug,问题是:在苹果手机Safari无痕浏览模式下系统登录成功但是页面不跳转. 思前想后找了半天没思路,后来经过同事的点拨,说可能是禁用了cookie之类的,反正我也没思路就顺 ...

  4. [ExtJS5学习笔记]第四节 欢迎来到extjs5-手把手教你实现你的第一个应用

    本文地址:http://blog.csdn.net/sushengmiyan/article/details/38331347 本文作者:sushengmiyan ------------------ ...

  5. [ExtJS5学习笔记]第十七节 Extjs5的panel组件增加accodion成为折叠导航栏

    本文地址:http://blog.csdn.net/sushengmiyan/article/details/39102335 官方例子:http://dev.sencha.com/ext/5.0.1 ...

  6. [ExtJS5学习笔记]第五节 使用fontawesome给你的extjs5应用增加字体图标

    本文地址:http://blog.csdn.net/sushengmiyan/article/details/38458411本文作者:sushengmiyan-------------------- ...

  7. [ExtJS5学习笔记]第五节 使用fontawesome给你的extjs5应用添加字体图标

    本文地址:http://blog.csdn.net/sushengmiyan/article/details/38458411本文作者:sushengmiyan-------------------- ...

  8. [ExtJS5学习笔记]第十节 Extjs5新增特性之ViewModel和DataBinding

    本文地址:http://blog.csdn.net/sushengmiyan/article/details/38612721 本文作者:sushengmiyan ------------------ ...

  9. [ExtJS5学习笔记]第二十节 Extjs5配合数组的push方法,动态创建并加载组件

    本文地址:http://blog.csdn.net/sushengmiyan/article/details/39226773 官方例子:http://docs.sencha.com/extjs/5. ...

随机推荐

  1. StopAllSounds

    10月3日,在杭州市西湖景区,一只小松鼠不停地接受一道道食物,花生.玉米.饼干,可谓来者不拒,憨态可掬的模样吸引了众多围观者...Description   小松鼠开心地在树之间跳跃着,突然她停了下来 ...

  2. hdu 5521 最短路

    Meeting Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Total ...

  3. 【USACO】 奶牛会展

    题目背景 奶牛想证明它们是聪明而风趣的.为此,贝西筹备了一个奶牛博览会,她已经对N 头奶牛进行 了面试,确定了每头奶牛的智商和情商. 题目描述 贝西有权选择让哪些奶牛参加展览.由于负的智商或情商会造成 ...

  4. HDU5339——Untitled

    Problem Description There is an integer a and n integers b1,…,bn. After selecting some numbers from  ...

  5. [bzoj4922]Karp-de-Chant Number

    来自FallDream的博客,未经允许,请勿转载,谢谢. 卡常数被称为计算机算法竞赛之中最神奇的一类数字,主要特点集中于令人捉摸不透,有时候会让水平很高的选手迷之超时. 普遍认为卡常数是埃及人Qa'a ...

  6. 左偏树(BZOJ4003)

    左偏树打个标记,没了. #include <cstdio> #include <vector> using namespace std; typedef long long l ...

  7. salt基本使用之一(1)

    1.帮助文档 以cmd函数为例子说下salt中的一些帮助信息 # 查看指定modules用法 salt '*' sys.doc cmd # 查看所有的modules列表 salt '*' sys.li ...

  8. SpringBoot 使用MultipartFile上传文件相关问题解决方案

    1.当上传时未配置上传内容大小,会报错[org.apache.tomcat.util.http.fileupload.FileUploadBase$SizeLimitExceededException ...

  9. 阿里Java研发工程师实习面经

    十分幸运 拿到阿里云的offer,感谢周围无数人对我的支持和鼓励,所以写篇面经希望可以帮助大家. 面试中,运气占很大一部分的,所以你们若是没有通过,一定不要气馁,继续加油. 每个努力的人 都值得钦佩, ...

  10. Java中的String,StringBuilder,StringBuffer三者的区别

    最近在学习Java的时候,遇到了这样一个问题,就是String,StringBuilder以及StringBuffer这三个类之间有什么区别呢,自己从网上搜索了一些资料,有所了解了之后在这里整理一下, ...