Heim Web-Frontend js-Tutorial 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()弹出对话框详解
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Autoloading-Mechanismus in PHP Autoloading-Mechanismus in PHP Jun 18, 2023 pm 01:11 PM

Da die PHP-Sprache immer beliebter wird, müssen Entwickler immer mehr Klassen und Funktionen verwenden. Wenn ein Projekt größer wird, wird es unpraktisch, alle Abhängigkeiten manuell einzuführen. Zu diesem Zeitpunkt ist ein automatischer Lademechanismus erforderlich, um den Codeentwicklungs- und Wartungsprozess zu vereinfachen. Der automatische Lademechanismus ist eine Funktion der PHP-Sprache, die erforderliche Klassen und Schnittstellen zur Laufzeit automatisch laden und die manuelle Einführung von Klassendateien reduzieren kann. Auf diese Weise können sich Programmierer auf die Entwicklung von Code konzentrieren und Fehler und Zeitverschwendung reduzieren, die durch mühsame manuelle Klasseneinführung entstehen. Im Allgemeinen in PHP

Wie Sie mit PHP und ExtJS leistungsstarke Webanwendungsfunktionen implementieren Wie Sie mit PHP und ExtJS leistungsstarke Webanwendungsfunktionen implementieren Jun 25, 2023 am 11:40 AM

Mit der kontinuierlichen Entwicklung und Beliebtheit von Webanwendungen beginnen immer mehr Unternehmen und Einzelpersonen, PHP und ExtJS zu verwenden, um leistungsstarke Webanwendungen zu erstellen. Als beliebte serverseitige Skriptsprache ist PHP plattformübergreifend und leicht zu erlernen, während ExtJS ein beliebtes Front-End-Framework ist, das Entwicklern helfen kann, schnell interaktive Webanwendungsschnittstellen zu erstellen. In diesem Artikel wird erläutert, wie Sie mit PHP und ExtJS leistungsstarke Webanwendungsfunktionen implementieren. Stellen Sie PHP- und MySQL-Datenbankverbindungen zur Nutzung her

Wie kann ich mit JavaScript Inhalte skalieren, die automatisch geladen werden, wenn zum Ende der Seite gescrollt wird, und den Effekt des Seitenverhältnisses beibehalten? Wie kann ich mit JavaScript Inhalte skalieren, die automatisch geladen werden, wenn zum Ende der Seite gescrollt wird, und den Effekt des Seitenverhältnisses beibehalten? Oct 27, 2023 pm 12:36 PM

Wie kann JavaScript eine automatische Skalierung des Inhalts beim Scrollen zum Ende der Seite erreichen und den Seitenverhältniseffekt beibehalten? Im modernen Webdesign ist das Scrollen zum Ende der Seite, um automatisch mehr Inhalte zu laden, zu einer häufigen Funktionsanforderung geworden. Wenn der geladene Inhalt Bilder enthält, möchten wir oft, dass diese Bilder ihr ursprüngliches Seitenverhältnis beibehalten. In diesem Artikel wird die Verwendung von JavaScript zum Implementieren dieser Funktion vorgestellt und entsprechende Codebeispiele als Referenz bereitgestellt. Zuerst müssen wir die Scrollposition der Seite ermitteln. inJavaScr

Wie verwende ich den Namespace und den automatischen Lademechanismus von PHP7, um die Struktur des Codes zu organisieren? Wie verwende ich den Namespace und den automatischen Lademechanismus von PHP7, um die Struktur des Codes zu organisieren? Oct 20, 2023 am 08:57 AM

Wie verwende ich den Namespace und den automatischen Lademechanismus von PHP7, um die Struktur des Codes zu organisieren? Zusammenfassung: Mit der Einführung von PHP7 sind Namespace und automatischer Lademechanismus zu wichtigen Funktionen geworden, die bei der PHP-Entwicklung nicht ignoriert werden können. In diesem Artikel wird erläutert, wie Sie den Namespace und den automatischen Lademechanismus von PHP7 verwenden, um die Struktur des Codes zu organisieren, und dies anhand spezifischer Codebeispiele veranschaulichen. 1. Was ist ein Namespace? Namespace ist ein in PHP7 eingeführter Mechanismus zur Lösung von Namenskonflikten, die zwischen verschiedenen Klassenbibliotheken oder Codedateien auftreten können. über Namensraum

So verwenden Sie Composer zum automatischen Laden in PHP So verwenden Sie Composer zum automatischen Laden in PHP Jun 23, 2023 am 10:27 AM

Composer ist ein sehr beliebtes Abhängigkeitsmanagement-Tool in PHP. Es kann uns dabei helfen, die im Projekt benötigten Bibliotheken und Komponenten von Drittanbietern zu verwalten und diese Bibliotheken und Komponenten automatisch zu laden. In diesem Artikel wird erläutert, wie Sie Composer zum automatischen Laden in PHP verwenden. Composer installieren Zuerst müssen Sie Composer installieren. Sie können die neueste Version von Composer unter https://getcomposer.org/download/ herunterladen und installieren. InitializeComp

Wie kann ich mit JavaScript einen Verlaufsanzeigeeffekt erzielen, bei dem Inhalte automatisch geladen werden, nachdem zum Ende der Seite gescrollt wurde? Wie kann ich mit JavaScript einen Verlaufsanzeigeeffekt erzielen, bei dem Inhalte automatisch geladen werden, nachdem zum Ende der Seite gescrollt wurde? Oct 16, 2023 am 08:54 AM

Wie erreicht JavaScript den Verlaufsanzeigeeffekt, bei dem Inhalte automatisch geladen werden, nachdem zum Ende der Seite gescrollt wurde? Im modernen Webdesign ist es eine häufige Anforderung, zum Ende der Seite zu scrollen, um Inhalte automatisch zu laden. Um das Benutzererlebnis zu verbessern, sind auch Verlaufsanzeigeeffekte eine gängige Designoption. Wie implementieren wir es also in JavaScript? Spezifische Implementierungsschritte und Codebeispiele sind unten aufgeführt. Die Hauptidee zur Erzielung dieses Effekts besteht darin, das Scroll-Ereignis der Seite zu überwachen und anhand der Scroll-Position festzustellen, ob das Ende der Seite erreicht wurde.

Wie kann ich mit JavaScript den Einblendeffekt erzielen, bei dem Inhalte automatisch geladen werden, nachdem zum Ende der Seite gescrollt wurde? Wie kann ich mit JavaScript den Einblendeffekt erzielen, bei dem Inhalte automatisch geladen werden, nachdem zum Ende der Seite gescrollt wurde? Oct 16, 2023 am 09:09 AM

Wie erreicht JavaScript den Einblendeffekt, bei dem Inhalte automatisch geladen werden, nachdem zum Ende der Seite gescrollt wurde? Im modernen Webdesign ist es eine sehr häufige Anforderung, zum Ende der Seite zu scrollen, um automatisch Inhalte mit Einblendeffekt zu laden. In diesem Artikel wird JavaScript als Beispiel verwendet, um vorzustellen, wie dieser Effekt erzielt werden kann. Zuerst müssen wir JavaScript verwenden, um auf Seiten-Scroll-Ereignisse zu warten. Wenn wir zum Ende der Seite scrollen, lösen wir eine Funktion aus, die neue Inhalte lädt. //Hören Sie sich das Seiten-Scroll-Ereignis an window.addEv

PHP Autoloading Masterclass: Werden Sie Experte für das Laden von Code PHP Autoloading Masterclass: Werden Sie Experte für das Laden von Code Mar 02, 2024 pm 09:43 PM

Einführung in das automatische Laden von PHP PHP-Autoloading ist ein Mechanismus, der es PHP ermöglicht, Klassen bei Bedarf automatisch zu laden, ohne die Dateien manuell einzubinden. Dies vereinfacht die Entwicklung großer Anwendungen erheblich und verbessert die Wartbarkeit des Codes. Namespaces und Autoloading-Namespaces in PHP werden zum Organisieren von Code verwendet. Wenn eine mit einem Namespace deklarierte Klasse geladen werden muss, führt PHP einen automatischen Ladevorgang durch. Der Autoloader ist dafür verantwortlich, die entsprechenden Klassendateien basierend auf dem Namespace und dem Klassennamen zu finden und zu laden. Verwenden von Composer zum Implementieren des automatischen Ladens Composer ist das Standardtool in der PHP-Community für Abhängigkeitsmanagement und automatisches Laden. Nach der Installation von Composer können Sie das automatische Laden mit den folgenden Schritten konfigurieren: //composer.JSO

See all articles