Extjs列表详细信息窗口新建后自动加载解决方法_extjs
在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()弹出对话框详解

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

随着PHP语言越来越受欢迎,开发人员需要使用越来越多的类和函数。当项目规模扩大时,手动引入所有依赖项将变得不切实际。这时候就需要一种自动加载机制来简化代码开发和维护过程。自动加载机制是一种PHP语言的特性,可以在运行时自动载入所需的类和接口,并减少手动的类文件引入。这样,程序员可以专注于开发代码,减少因繁琐的手动类引入而产生的错误和时间浪费。在PHP中,一般

随着Web应用的不断发展和普及,越来越多的企业和个人开始使用PHP和ExtJS来构建功能强大的Web应用。PHP作为一种流行的服务器端脚本语言,具有良好的跨平台性和易于学习的特点,而ExtJS则是一种流行的前端框架,可以帮助开发人员快速构建交互式Web应用界面。本文将介绍如何使用PHP和ExtJS实现强大Web应用功能。建立PHP和MySQL数据库连接在使用

JavaScript如何实现滚动到页面底部自动加载的内容缩放并保持纵横比效果?在现代网页设计中,滚动到页面底部自动加载更多内容已经成为了常见的功能需求。而当加载的内容包含图片时,我们常常希望这些图片能够保持原有的纵横比。本文将介绍如何使用JavaScript来实现这个功能,并提供相应的代码示例供参考。首先,我们需要获取页面滚动的位置。在JavaScr

如何利用PHP7的命名空间和自动加载机制组织代码的结构?摘要:随着PHP7的推出,命名空间和自动加载机制成为了PHP开发中不可忽视的重要特性。本文将介绍如何利用PHP7的命名空间和自动加载机制来组织代码的结构,并通过具体的代码示例进行说明。一、什么是命名空间?命名空间是PHP7引入的一种机制,用于解决不同类库或代码文件之间可能出现的命名冲突问题。通过命名空间

Composer是PHP中一个非常流行的依赖管理工具,可以帮助我们管理项目中需要的第三方库和组件,并自动加载这些库和组件。本文将介绍如何在PHP中使用Composer进行自动加载。安装Composer首先,你需要安装Composer。你可以在https://getcomposer.org/download/下载Composer的最新版本并安装。初始化Comp

JavaScript如何实现滚动到页面底部自动加载的内容渐变显示效果?在现代的网页设计中,滚动到页面底部自动加载内容是一个常见的需求。而为了提升用户体验,渐变显示效果也是一个常见的设计选项。那么,在JavaScript中,我们如何进行实现呢?下面将给出具体的实现步骤和代码示例。实现该效果的主要思路是监听页面的滚动事件,并根据滚动位置来判断是否到达页面底

JavaScript如何实现滚动到页面底部自动加载的内容淡入效果?在现代的网页设计中,实现滚动到页面底部自动加载内容并且带有淡入效果是非常常见的需求。本文将以JavaScript为例,介绍如何实现这一效果。首先,我们需要利用JavaScript监听页面滚动事件。当滚动到页面底部时,我们将触发加载新内容的函数。//监听页面滚动事件window.addEv

PHP自动加载介绍PHP自动加载是一种机制,允许php在需要时自动加载类,而无需手动包含文件。这极大地简化了大型应用程序的开发,并提高了代码的可维护性。命名空间和自动加载PHP中的命名空间用于组织代码。当使用命名空间声明的类需要被加载时,PHP将执行自动加载流程。自动加载器负责根据命名空间和类名查找并加载相应的类文件。使用Composer实现自动加载Composer是PHP社区中用于依赖管理和自动加载的标准工具。安装Composer后,您可以使用以下步骤配置自动加载://composer.JSO
