Maison interface Web js tutoriel Extjs列表详细信息窗口新建后自动加载解决方法_extjs

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

May 16, 2016 pm 06:30 PM
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()弹出对话框详解
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Mécanisme de chargement automatique en PHP Mécanisme de chargement automatique en PHP Jun 18, 2023 pm 01:11 PM

À mesure que le langage PHP devient de plus en plus populaire, les développeurs doivent utiliser de plus en plus de classes et de fonctions. Lorsqu'un projet grandit, l'introduction manuelle de toutes les dépendances devient peu pratique. À l’heure actuelle, un mécanisme de chargement automatique est nécessaire pour simplifier le processus de développement et de maintenance du code. Le mécanisme de chargement automatique est une fonctionnalité du langage PHP qui peut charger automatiquement les classes et interfaces requises au moment de l'exécution et réduire l'introduction manuelle des fichiers de classe. De cette façon, les programmeurs peuvent se concentrer sur le développement du code et réduire les erreurs et la perte de temps causées par une introduction manuelle fastidieuse aux cours. En PHP, généralement

Comment utiliser PHP et ExtJS pour implémenter de puissantes fonctions d'application Web Comment utiliser PHP et ExtJS pour implémenter de puissantes fonctions d'application Web Jun 25, 2023 am 11:40 AM

Avec le développement continu et la popularité des applications Web, de plus en plus d'entreprises et de particuliers commencent à utiliser PHP et ExtJS pour créer de puissantes applications Web. En tant que langage de script côté serveur populaire, PHP est multiplateforme et facile à apprendre, tandis qu'ExtJS est un framework frontal populaire qui peut aider les développeurs à créer rapidement des interfaces d'applications Web interactives. Cet article explique comment utiliser PHP et ExtJS pour implémenter de puissantes fonctions d'application Web. Établir des connexions aux bases de données PHP et MySQL à utiliser

Comment utiliser JavaScript pour mettre à l'échelle le contenu qui se charge automatiquement lors du défilement vers le bas de la page tout en conservant l'effet de format ? Comment utiliser JavaScript pour mettre à l'échelle le contenu qui se charge automatiquement lors du défilement vers le bas de la page tout en conservant l'effet de format ? Oct 27, 2023 pm 12:36 PM

Comment JavaScript peut-il réaliser une mise à l'échelle automatique du contenu lors du défilement vers le bas de la page et conserver l'effet de format ? Dans la conception Web moderne, faire défiler vers le bas de la page pour charger automatiquement plus de contenu est devenu une exigence courante en matière de fonctionnalités. Lorsque le contenu chargé contient des images, nous souhaitons souvent que ces images conservent leur rapport hauteur/largeur d'origine. Cet article explique comment utiliser JavaScript pour implémenter cette fonction et fournit des exemples de code correspondants à titre de référence. Tout d’abord, nous devons obtenir la position de défilement de la page. enJavaScr

Comment utiliser l'espace de noms et le mécanisme de chargement automatique de PHP7 pour organiser la structure du code ? Comment utiliser l'espace de noms et le mécanisme de chargement automatique de PHP7 pour organiser la structure du code ? Oct 20, 2023 am 08:57 AM

Comment utiliser l'espace de noms et le mécanisme de chargement automatique de PHP7 pour organiser la structure du code ? Résumé : Avec le lancement de PHP7, l'espace de noms et le mécanisme de chargement automatique sont devenus des fonctionnalités importantes qui ne peuvent être ignorées dans le développement PHP. Cet article présentera comment utiliser l'espace de noms et le mécanisme de chargement automatique de PHP7 pour organiser la structure du code et l'illustrera à travers des exemples de code spécifiques. 1. Qu'est-ce qu'un espace de noms ? L'espace de noms est un mécanisme introduit dans PHP7 pour résoudre les conflits de noms pouvant survenir entre différentes bibliothèques de classes ou fichiers de code. via l'espace de noms

Comment utiliser Composer pour le chargement automatique en PHP Comment utiliser Composer pour le chargement automatique en PHP Jun 23, 2023 am 10:27 AM

Composer est un outil de gestion des dépendances très populaire en PHP. Il peut nous aider à gérer les bibliothèques et composants tiers nécessaires au projet et à charger automatiquement ces bibliothèques et composants. Cet article explique comment utiliser Composer pour le chargement automatique en PHP. Installer Composer Tout d'abord, vous devez installer Composer. Vous pouvez télécharger la dernière version de Composer sur https://getcomposer.org/download/ et l'installer. InitialiserComp

Comment utiliser JavaScript pour obtenir un effet d'affichage dégradé en chargeant automatiquement le contenu après un défilement vers le bas de la page ? Comment utiliser JavaScript pour obtenir un effet d'affichage dégradé en chargeant automatiquement le contenu après un défilement vers le bas de la page ? Oct 16, 2023 am 08:54 AM

Comment JavaScript obtient-il l'effet d'affichage dégradé en chargeant automatiquement le contenu lors du défilement vers le bas de la page ? Dans la conception Web moderne, faire défiler vers le bas de la page pour charger automatiquement le contenu est une exigence courante. Afin d'améliorer l'expérience utilisateur, les effets d'affichage en dégradé sont également une option de conception courante. Alors, comment l’implémenter en JavaScript ? Des étapes de mise en œuvre spécifiques et des exemples de code sont donnés ci-dessous. L'idée principale pour obtenir cet effet est de surveiller l'événement de défilement de la page et de déterminer si le bas de la page a été atteint en fonction de la position de défilement.

Comment utiliser JavaScript pour obtenir l'effet de fondu du chargement automatique du contenu après un défilement vers le bas de la page ? Comment utiliser JavaScript pour obtenir l'effet de fondu du chargement automatique du contenu après un défilement vers le bas de la page ? Oct 16, 2023 am 09:09 AM

Comment JavaScript obtient-il l'effet de fondu en chargeant automatiquement le contenu après un défilement vers le bas de la page ? Dans la conception Web moderne, il est très courant de faire défiler la page vers le bas pour charger automatiquement le contenu avec un effet de fondu. Cet article utilisera JavaScript comme exemple pour présenter comment obtenir cet effet. Tout d’abord, nous devons utiliser JavaScript pour écouter les événements de défilement de page. En faisant défiler vers le bas de la page, nous déclencherons une fonction qui chargera du nouveau contenu. //Écoutez l'événement de défilement de page window.addEv

Masterclass de chargement automatique PHP : devenez un expert en chargement de code Masterclass de chargement automatique PHP : devenez un expert en chargement de code Mar 02, 2024 pm 09:43 PM

Introduction au chargement automatique PHP Le chargement automatique PHP est un mécanisme qui permet à PHP de charger automatiquement les classes en cas de besoin sans inclure manuellement les fichiers. Cela simplifie grandement le développement de grandes applications et améliore la maintenabilité du code. Les espaces de noms et les espaces de noms à chargement automatique en PHP sont utilisés pour organiser le code. Lorsqu'une classe déclarée à l'aide d'un espace de noms doit être chargée, PHP effectuera un processus de chargement automatique. Le chargeur automatique est chargé de rechercher et de charger les fichiers de classe correspondants en fonction de l'espace de noms et du nom de classe. Utiliser Composer pour implémenter le chargement automatique Composer est l'outil standard de la communauté PHP pour la gestion des dépendances et le chargement automatique. Après avoir installé Composer, vous pouvez configurer le chargement automatique en suivant les étapes suivantes : //composer.JSO

See all articles