再探 Ext JS 6 (sencha touch/ext升级版) 变化篇 (编译命令、滚动条、控制层、模型层、路由)
从sencha touch 2.4.2升级到ext js 6,cmd版本升级到6.0之后发生了很多变化
首先从cmd说起,cmd 6 中sencha app build package不能使用了,sencha app build native好像也不能用了。
有个好消息就是我们可以用
sencha ant native build
sencha ant package build
这两个命令,目测和以前的效果差不多了
然后再说说ext js 6相对sencha touch 2.4.2的变化
首先最只管的就是在网页上滚动条变了,如图
移动端没有变化,如图
想要统一他们的显示效果可能需要花一下心思看看源码了
然后控制层和模型层发生了变化
以前的控制层是这样,如图
现在是这样,如图
也就是说views,models,还有图片上没显示的stores现在是和config配置同级了,楼主搞了半天才明白错在那里
另外模型层也发生了变化
以前是这样,如图
现在是这样,如图
没有了config,奇怪的是数据仓库层,也就是store没有变化,很奇怪。
另外原来sencha touch如果你重写了模型和验证模块,现在大概是不能用了,需要重新看源码来写了,楼主的自定义验证模块完全就废了。
最后就是路由这一块发生了变化,这个变化挺大的。例如
this.redirectTo('redirect/newsInfo');
util.recordLoad(this.getInfo(), config.news.info, {
NewsID: record.get('id'),
UserID: config.userMes ? config.userMes.id : 0
}, record, 'Info');
在sencha touch中,this.redirectTo('redirect/newsInfo');这行代码会触发我在main控制层中的视图切换方法,也就是以下代码。
showView: function (view, count) {
//如果正在登录中,中断执行
if (config.isLogin) {
return;
}
var main = this.getMain() || this.getLogin(),
params = config.tmpParams;
if (main) {
//登录检测
//根据config.ckLogin和用户信息检测
if (config.ckLogin[view] && !config.userMes.id) {
//没有登录则跳转到登录页面
params = params || {};
//为登录页面添加配置,登录成功后判断跳转位置
params.redirect = view;
view = 'userLogin';
}
if (!view) {
count = 1;
}
if (count && !Ext.isNumber(count) && count.match(/^\+?[1-9][0-9]*$/)) {
count = Number(count);
}
if (count) {
main.popAndPush(view, count, params);
} else {
main.push(view, params);
}
}
delete config.tmpParams;
}
在这里动态创建了newsInfo视图,然后通过this.getInfo()方法获取到视图对象,最后给这个视图赋值。
在ext js 6中,这个代码完全失效了,经过测试发现showView方法的执行顺序在util.recordLoad这段代码之后执行了,也就是说这个时候this.getInfo()方法获取的是一个null
怎么办?我们可以这样处理
this.redirectTo('redirect/newsInfo',true);
强制触发路由事件,不过这样你会发现showView这个方法被触发了两次,这样怎么可以!怎么办?重写路由这一块!代码如下
Ext.define('Ext.zh.util.History', {
override: 'Ext.util.History',
//因为在redirectTo里面已经触发了方法,所以这里就不应该再次触发,直接清空
handleStateChange: function (token) {
}
});
Ext.define('Ext.zh.app.BaseController', {
override: 'Ext.app.BaseController',
redirectTo: function (token) {
if (token.isModel) {
token = token.toUrl();
}
//立刻执行路由触发的方法,没有做重复触发判定,使用过程中注意处理
Ext.app.route.Router.onStateChange(token);
//加入历史记录,如果不想url发生变化,可以注释掉
//Ext.util.History.add(token);
return true;
}
});
这样勉强达到了sencha touch中的效果,不过问题有来了,在ajax请求数据时,会有问题,代码如下:
recordLoad: function (view, url, params, record, ckName) {
//如果record存在,并且ckName这个字段中有值
//所以已经请求过了,直接设置值即可
if (record && record.get(ckName)) {
view.setRecord(record);
return;
}
//据需求决定用jsonp还是ajax
//Ext.data.JsonP.request
Ext.Ajax.request({
url: url,
params: params,
success: function (data) {
//处理返回值,转换为json对象
data = Ext.decode(data.responseText)[0] || Ext.decode(data.responseText);
//如果模型存在,直接赋值,并且给详细视图赋值
//如果涉及到修改这一块,模型存在会省很多事
//请看http://www.cnblogs.com/mlzs/archive/2013/05/29/3106241.html
if (record) {
record.set(data);
view.setRecord(record);
} else {
//如果模型不存在,直接给详细视图赋值
view.setData(data);
}
}
});
}
如果使用navigationView,在第二次进入视图时会报错,目前还没找到解决方法!如图
最后代码改成这样
config.tmpParams.record = record;
this.redirectTo('redirect/newsInfo')
util.recordLoad(config.news.info, {
NewsID: record.get('id'),
UserID: config.userMes ? config.userMes.id : 0
}, record, 'Info');
关键代码 config.tmpParams.record = record;这里通过路由触发的方法处理,会把record直接初始化给newsInfo视图,这样不会出错,很奇怪。
recordLoad: function (url, params, record, ckName) {
//如果record存在,并且ckName这个字段中有值
//所以已经请求过了,直接设置值即可
if (record && record.get(ckName)) {
return;
}
//据需求决定用jsonp还是ajax
//Ext.data.JsonP.request
Ext.Ajax.request({
url: url,
params: params,
success: function (data) {
//处理返回值,转换为json对象
data = Ext.decode(data.responseText)[0] || Ext.decode(data.responseText);
record.set(data);
}
});
},
感觉坑还是挺多的,各位有啥好的填坑方法记得告诉我。我会继续分享我的心得。
再探 Ext JS 6 (sencha touch/ext升级版) 变化篇 (编译命令、滚动条、控制层、模型层、路由)的更多相关文章
- 初探 Ext JS 6 (sencha touch/ext升级版)
Sencha Touch 现在已全面升级至Ext Js 6,那么我们如何使用他们呢? 首先去官网下载最新的sdk和帮助文档 sdk下载地址:https://www.sencha.com/product ...
- 【翻译】在Ext JS和Sencha Touch中创建自己定义布局
原文:Creating Custom Layouts in Ext JS and Sencha Touch 布局系统是Sencha框架中最强大和最独特的一部分.布局会处理应用程序中每个组件的大小和位置 ...
- 【翻译】在Ext JS和Sencha Touch中创建自定义布局
原文:Creating Custom Layouts in Ext JS and Sencha Touch 布局系统是Sencha框架中最强大和最独特的一部分.布局会处理应用程序中每个组件的大小和位置 ...
- 【翻译】为Ext JS和Sencha Touch开发人员准备的应用程序监测(App Inspector)
和其他的Sencha开发人员一样,我会花费大约半天的时间在我喜欢的IDE工具上编写JavaScript,而另一半时间则是在浏览器上测试和调试我的应用程序.在过去几年,每一个主要的浏览器都已大为改善.现 ...
- sencha touch Ext.app.Application
Ext.app.Application一般用于app.js中 用来初始化整个应用 可以预先加载controllers(控制器),models(模型),stores(数据源),views(视图) 例如: ...
- Ext JS学习第九天 Ext基础之 扩展原生的javascript对象
此文来记录学习笔记: •Ext对于原生的javascript对象进行了一系列的扩展,我们把他们掌握好,更能深刻的体会Ext的架构,从而对我们的web开发更好的服务, 源码位置,我们可以从开发包的这个位 ...
- Ext JS学习第八天 Ext基础之 认识Ext.js 和Ext-more.js
此文来记录学习笔记: •认识Ext.js 和Ext-more.js •首先,我们要知道这2个js文件的作用,这俩个文件包含了Ext的一些基础定义.基本的属性和方法,我们要重点学习和深入底层代码进行研究 ...
- sencha touch 入门系列 扩展篇之sencha touch 项目打包压缩
经常有新手同学抱怨说sencha touch的项目加载速度为什么这么慢,经常要10秒左右的时间甚至更多, 大家都知道,sencha touch开发的项目中引用了大量的js文件,当我们打开项目时,st的 ...
- sencha touch/Ext Js 6 + 自定义扩展的用法
app.js中加入以下代码 //指定ux起调目录 Ext.Loader.setPath({ 'ux': 'app/ux' }); 在app目录中创建一个ux文件夹 假如我们使用这个扩展,扩展地址:ht ...
随机推荐
- 从源代码分析Universal-Image-Loader中的线程池
一般来讲一个网络访问就需要App创建一个线程来执行,但是这也导致了当网络访问比较多的情况下,线程的数目可能积聚增多,虽然Android系统理论上说可以创建无数个线程,但是某一时间段,线程数的急剧增加可 ...
- Apache axis2 + Eclipse 开发 WebService
yd小结注意:1.axis2的2个插件的版本必须与引入的jar包匹配,如果不同则可能报以下错误 “没有实现序列化方法”或 “org.apache.axis2.databinding.utils.wri ...
- Failed to initialize the Common Language Runtime
今天在SQL Server 2008中执行存储过程的时候报以下错误: Msg , Level , State , Procedure usp_QueryRealTimeRoomInfo, Line F ...
- 如何设置iframe高度自适应,在跨域的情况下能做到吗?
在页面上使用iframe来动态加载页面内容是网页开发中比较常见的方法.在父页面中给定一个不带滚动条的iframe,然后对属性src指定一个可加载的页面,这样当父页面被访问的时候,子页面可以被自动加载. ...
- PAIP.MYSQL SLEEP 连接太多解决
PAIP.MYSQL SLEEP 连接太多解决 作者Attilax 艾龙, EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://blog.csdn.n ...
- paip.c3p0 数据库连接池 NullPointerException 的解决...
paip.c3p0 数据库连接池 NullPointerException 的解决... 程序ide里面运行正常..外面bat运行错误.. 作者Attilax 艾龙, EMAIL:14665198 ...
- paip.hql的调试故障排查流程总结
paip.hql的调试故障排查流程总结 环境.myeclipse7.0 1 Hql的调试工具myeclipxe默认工具.../Hibernate8IDE 1 故障的排除方法overview 1 Hql ...
- paip.导入数据英文音标到数据库mysql为空的问题之道解决原理
paip.导入数据英文音标到数据库mysql为空的问题之道解决原理 #---原因:mysql 导入工具的bug #---解决:使用双引号不个音标括起来. 作者 老哇的爪子 Attilax 艾龙, E ...
- SHINY-SERVER R(sparkR)语言web解决方案 架设shiny服务器
1. shiny server简介 shiny-server是一种可用把R 语言以web形式展示的服务,其实RStudio公司自己构建了R Shiny Application运行的平台(http:// ...
- js系列(9)js的运用(一)
本节开始介绍javascript在html页面中的运用. (1)link样式表的动态绑定:(http://files.cnblogs.com/files/MenAngel/text04 ...