Extjs列表详细信息窗口新建后自动加载解决方法


Posted in Javascript onApril 02, 2010

在Extjs中,在当前页面的grid页新建了一行数据后,通过表单形式进入详细页面的编辑,此时,为了能让页面自动打开详细页面编辑,我花了三个小时,终于找到了在Extjs下最合适的方案,结果却只有三句话,我想,这可能也是很多Extjs爱好者们想要知道或者已经知道的,为此,将其与大家分享,只求为extjs群体贡献自己的一些想法。

列表在创建后,一般会有一个提示,现在我把我最开始的几个思路与大家讲讲,想直接看结果的可以跳到最后一套方案~

方案1(放弃). 在新建数据后,向createform方法传送一个id值。这可能是普通搞web的大虾们最先想到的方法,通过传参给一个detail页,然后detail根据id再到库中查找相应的数据,显示在页面上。可是,经过调查,发现页面是通过当前页面的子窗口的方式来显示的,而子窗口的数据是通过grid中的每行数据来传入的,如果要想显示二级页,首先要在grid中读取出一条数据,将整体作为一条record传值才可。而添加数据后,本身就是要更新列表的,还不如直接读取列表中的最新一条数据,直接传入,恩, 这就想到了第二套方案~

方案2(成功). 在数据创建并更新列表后,设定列表中的第一项(因为根据创建时间排序了的)为选中状态,调用onEdit方法,相当于点击了grid中的第一行数据并点编辑按钮的效果(ps:我是不是很有才呀)。好了,在save数据的方法后面,调用grid.selModel.selectRow(0),然后grid.onEdit()(自己定义的编辑方法,通过grid.getSelectionModel().getSelected()取出已选的行,并将参数传递给form),要注意了,这里直接选中的话,是选的列表更新前的第一条(不是我们想要的更新后的第一条哦)~~因为store的load是异步加载的,哈哈,所以这里呢,要把这两个方法放到setTimeout函数里面,像这样:

setTimeout(function(){ 
Ext.getCmp("gridPanel").sm.selectRow(0); 
Ext.getCmp("gridPanel").onEdit(); 
},300);

设定一下延迟,然后再执行选择和编辑方法就行啦。有没有发现,这里我用的是getCmp,而不是this.grid?因为setTimeout在js中的作用域是全局的,所以如果在这里用了局部变量,js将会报错“未定义的对象或者方法”。可是,用的时候又发现一个问题,这个延迟时间感觉有点长了,而且,有延迟让人感觉老是不爽,可不可以不用这个函数就搞定呢?于是乎,终极方案即将出炉啦!这是我冥思苦想无果但是无意中发现的方法哦,嘿嘿,有那么丁点投机取巧的感觉,大家不要笑我哦,哈哈~
我也是新手,刚学Extjs没多久,而且js也不那么熟,估计搁熟手那,这些小问题都是鸡毛蒜皮不当回事的,可是我想到这个后感觉还是挺有成就感的,高手直接略过,就别听我??铝耍?呛?
方案3(最佳). 在Extjs的message窗口的回调函数中选择列表并打开详细。这就是我的最佳方案。因为我发现Ext对Ext.Msg.alert()方法提供了四个参数,分别是title,msg,fn,scope(见参考博文)其中,fn就是回调函数块的内容,在点击按钮后将调用该函数,我把上面两句代码放在回调函数里,就解决了延迟加载和用户体验的两大问题,真是两全其美,何乐而不为呢?
Ext.Msg.alert("提示信息", "新建成功,请输入详细信息!", function() { 
this.grid.sm.selectRow(0); 
this.grid.onEdit(); 
}, this);

虽然看起来代码没几行,可是却消耗了我不少脑细胞啊,为了想出这个方案,试验并调试了几十次,大家如果觉得有用,别忘顶贴哦~
解决问题的过程中,参考了以下博文:
ExtJS Ext.MessageBox.alert()弹出对话框详解
Javascript 相关文章推荐
返回顶部按钮响应滚动且动态显示与隐藏
Oct 14 Javascript
JQuery记住用户名密码实现下次自动登录功能
Apr 27 Javascript
以jQuery中$.Deferred对象为例讲解promise对象是如何处理异步问题
Nov 13 Javascript
jQuery移动web开发之页面跳转和加载外部页面的实现
Dec 04 Javascript
JS区分浏览器页面是刷新还是关闭
Apr 17 Javascript
Node.js配合node-http-proxy解决本地开发ajax跨域问题
Aug 31 Javascript
Three.js利用性能插件stats实现性能监听的方法
Sep 25 Javascript
jQuery实现的点击按钮改变样式功能示例
Jul 21 jQuery
vue路由中前进后退的一些事儿
May 18 Javascript
基于Layui自定义模块的使用方法详解
Sep 14 Javascript
Vue axios与Go Frame后端框架的Options请求跨域问题详解
Mar 03 Javascript
Node.js API详解之 querystring用法实例分析
Apr 29 Javascript
JavaScript 一行代码,轻松搞定浮动快捷留言-V2升级版
Apr 02 #Javascript
js 刷新页面的代码小结 推荐
Apr 02 #Javascript
JQuery 插件制作实践 xMarquee插件V1.0
Apr 02 #Javascript
Jquery 插件学习实例1 插件制作说明与tableUI优化
Apr 02 #Javascript
jquery ui 1.7 ui.tabs 动态添加与关闭(按钮关闭+双击关闭)
Apr 01 #Javascript
初试jQuery EasyUI 使用介绍
Apr 01 #Javascript
跟我一起学写jQuery插件开发方法(附完整实例及下载)
Apr 01 #Javascript
You might like
自己动手,丰衣足食 - 短波框形天线制作
2021/03/01 无线电
杏林同学录(五)
2006/10/09 PHP
生成php程序的php代码
2008/04/07 PHP
根据邮箱的域名跳转到相应的登录页面的代码
2012/02/27 Javascript
JS取request值以及自动执行使用示例
2014/02/24 Javascript
深入分析Cookie的安全性问题
2015/03/01 Javascript
JavaScript页面实时显示当前时间实例代码
2016/10/23 Javascript
实现easyui的datagrid导出为excel的示例代码
2016/11/10 Javascript
利用js判断手机是否安装某个app的多种方案
2017/02/13 Javascript
vue 挂载路由到头部导航的方法
2017/11/13 Javascript
Angular 组件之间的交互的示例代码
2018/03/24 Javascript
基于js实现复制内容到操作系统粘贴板过程解析
2019/10/11 Javascript
vue中element 的upload组件发送请求给后端操作
2020/09/07 Javascript
Openlayers学习之加载鹰眼控件
2020/09/28 Javascript
[01:14:35]DOTA2上海特级锦标赛B组资格赛#1 Alliance VS Fnatic第一局
2016/02/26 DOTA
Python Tkinter基础控件用法
2014/09/03 Python
低版本中Python除法运算小技巧
2015/04/05 Python
编写Python脚本抓取网络小说来制作自己的阅读器
2015/08/20 Python
Python数据结构与算法之使用队列解决小猫钓鱼问题
2017/12/14 Python
利用python GDAL库读写geotiff格式的遥感影像方法
2018/11/29 Python
调试Django时打印SQL语句的日志代码实例
2019/09/12 Python
利用python实现AR教程
2019/11/20 Python
python内打印变量之%和f的实例
2020/02/19 Python
在python下实现word2vec词向量训练与加载实例
2020/06/09 Python
利用Python将图片中扭曲矩形的复原
2020/09/07 Python
纯CSS实现右侧底部悬浮效果(悬浮QQ、微信、微博、邮箱等联系方式)
2015/04/24 HTML / CSS
领先的钻石和订婚戒指零售商:Diamonds-USA
2016/12/11 全球购物
给客户的道歉信
2014/01/13 职场文书
应届电子商务毕业自荐书范文
2014/02/11 职场文书
《蚕姑娘》教学反思
2014/04/15 职场文书
竞聘上岗演讲
2014/05/19 职场文书
信息管理专业自荐书
2014/06/05 职场文书
就业意向书
2014/07/29 职场文书
吃空饷专项整治方案
2014/10/27 职场文书
公积金贷款承诺书
2015/04/30 职场文书
Angular性能优化之第三方组件和懒加载技术
2021/05/10 Javascript