Rumah hujung hadapan web tutorial js Extjs列表详细信息窗口新建后自动加载解决方法_extjs

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

May 16, 2016 pm 06:30 PM
extjs autoload

在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()弹出对话框详解
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Mekanisme pemuatan automatik dalam PHP Mekanisme pemuatan automatik dalam PHP Jun 18, 2023 pm 01:11 PM

Apabila bahasa PHP menjadi semakin popular, pembangun perlu menggunakan lebih banyak kelas dan fungsi. Apabila projek berkembang dalam saiz, memperkenalkan semua kebergantungan secara manual menjadi tidak praktikal. Pada masa ini, mekanisme pemuatan automatik diperlukan untuk memudahkan proses pembangunan dan penyelenggaraan kod. Mekanisme pemuatan automatik ialah ciri bahasa PHP yang boleh memuatkan kelas dan antara muka yang diperlukan secara automatik pada masa jalan dan mengurangkan pengenalan fail kelas manual. Dengan cara ini, pengaturcara boleh menumpukan pada membangunkan kod dan mengurangkan ralat dan pembaziran masa yang disebabkan oleh pengenalan kelas manual yang membosankan. Dalam PHP, secara amnya

Cara menggunakan PHP dan ExtJS untuk melaksanakan fungsi aplikasi web yang berkuasa Cara menggunakan PHP dan ExtJS untuk melaksanakan fungsi aplikasi web yang berkuasa Jun 25, 2023 am 11:40 AM

Dengan pembangunan berterusan dan populariti aplikasi Web, semakin banyak syarikat dan individu mula menggunakan PHP dan ExtJS untuk membina aplikasi Web yang berkuasa. Sebagai bahasa skrip sebelah pelayan yang popular, PHP adalah merentas platform dan mudah dipelajari, manakala ExtJS ialah rangka kerja bahagian hadapan yang popular yang boleh membantu pembangun membina antara muka aplikasi web interaktif dengan cepat. Artikel ini akan memperkenalkan cara menggunakan PHP dan ExtJS untuk melaksanakan fungsi aplikasi web yang berkuasa. Wujudkan sambungan pangkalan data PHP dan MySQL untuk digunakan

Bagaimana untuk menggunakan JavaScript untuk menskalakan kandungan yang dimuatkan secara automatik apabila menatal ke bahagian bawah halaman sambil mengekalkan kesan nisbah aspek? Bagaimana untuk menggunakan JavaScript untuk menskalakan kandungan yang dimuatkan secara automatik apabila menatal ke bahagian bawah halaman sambil mengekalkan kesan nisbah aspek? Oct 27, 2023 pm 12:36 PM

Bagaimanakah JavaScript boleh mencapai penskalaan automatik kandungan apabila menatal ke bahagian bawah halaman dan mengekalkan kesan nisbah aspek? Dalam reka bentuk web moden, menatal ke bahagian bawah halaman untuk memuatkan lebih banyak kandungan secara automatik telah menjadi keperluan ciri biasa. Apabila kandungan yang dimuatkan mengandungi imej, kami selalunya mahu imej ini mengekalkan nisbah aspek asalnya. Artikel ini akan memperkenalkan cara menggunakan JavaScript untuk melaksanakan fungsi ini dan menyediakan contoh kod yang sepadan untuk rujukan. Pertama, kita perlu mendapatkan kedudukan tatal halaman. dalamJavaScr

Bagaimana untuk menggunakan ruang nama PHP7 dan mekanisme pemuatan automatik untuk mengatur struktur kod? Bagaimana untuk menggunakan ruang nama PHP7 dan mekanisme pemuatan automatik untuk mengatur struktur kod? Oct 20, 2023 am 08:57 AM

Bagaimana untuk menggunakan ruang nama PHP7 dan mekanisme pemuatan automatik untuk mengatur struktur kod? Abstrak: Dengan pelancaran PHP7, ruang nama dan mekanisme pemuatan automatik telah menjadi ciri penting yang tidak boleh diabaikan dalam pembangunan PHP. Artikel ini akan memperkenalkan cara menggunakan ruang nama PHP7 dan mekanisme pemuatan automatik untuk mengatur struktur kod, dan menggambarkannya melalui contoh kod tertentu. 1. Apakah ruang nama? Ruang nama ialah mekanisme yang diperkenalkan dalam PHP7 untuk menyelesaikan konflik penamaan yang mungkin berlaku antara perpustakaan kelas atau fail kod yang berbeza. melalui ruang nama

Cara menggunakan Komposer untuk autoloading dalam PHP Cara menggunakan Komposer untuk autoloading dalam PHP Jun 23, 2023 am 10:27 AM

Komposer ialah alat pengurusan pergantungan yang sangat popular dalam PHP. Ia boleh membantu kami mengurus perpustakaan dan komponen pihak ketiga yang diperlukan dalam projek dan memuatkan perpustakaan dan komponen ini secara automatik. Artikel ini akan memperkenalkan cara menggunakan Komposer untuk memuatkan automatik dalam PHP. Pasang Komposer Mula-mula, anda perlu memasang Komposer. Anda boleh memuat turun versi terkini Komposer di https://getcomposer.org/download/ dan memasangnya. InitializeComp

Bagaimana untuk menggunakan JavaScript untuk mencapai kesan pudar dalam memuatkan kandungan secara automatik selepas menatal ke bahagian bawah halaman? Bagaimana untuk menggunakan JavaScript untuk mencapai kesan pudar dalam memuatkan kandungan secara automatik selepas menatal ke bahagian bawah halaman? Oct 16, 2023 am 09:09 AM

Bagaimanakah JavaScript mencapai kesan pudar dalam memuatkan kandungan secara automatik selepas menatal ke bahagian bawah halaman? Dalam reka bentuk web moden, adalah keperluan biasa untuk menatal ke bahagian bawah halaman untuk memuatkan kandungan secara automatik dengan kesan pudar. Artikel ini akan menggunakan JavaScript sebagai contoh untuk memperkenalkan cara mencapai kesan ini. Pertama, kita perlu menggunakan JavaScript untuk mendengar acara tatal halaman. Apabila menatal ke bahagian bawah halaman, kami akan mencetuskan fungsi yang memuatkan kandungan baharu. //Dengar tetingkap acara tatal halaman.addEv

Kelas Induk Pemuatan Auto PHP: Menjadi Pakar Pemuatan Kod Kelas Induk Pemuatan Auto PHP: Menjadi Pakar Pemuatan Kod Mar 02, 2024 pm 09:43 PM

Pengenalan kepada PHP Autoloading PHP autoloading ialah mekanisme yang membolehkan PHP memuatkan kelas secara automatik apabila diperlukan tanpa memasukkan fail secara manual. Ini sangat memudahkan pembangunan aplikasi besar dan meningkatkan kebolehselenggaraan kod. Ruang Nama dan Ruang Nama Muat Auto dalam PHP digunakan untuk menyusun kod. Apabila kelas yang diisytiharkan menggunakan ruang nama perlu dimuatkan, PHP akan melaksanakan proses pemuatan automatik. Autoloader bertanggungjawab untuk mencari dan memuatkan fail kelas yang sepadan berdasarkan ruang nama dan nama kelas. Pemuatan automatik menggunakan Composer Composer ialah alat standard dalam komuniti PHP untuk pengurusan pergantungan dan pemuatan automatik. Selepas memasang Komposer, anda boleh mengkonfigurasi autoloading menggunakan langkah berikut: //composer.JSO

Bagaimana untuk menggunakan JavaScript untuk mencapai kesan paparan kecerunan untuk memuatkan kandungan secara automatik selepas menatal ke bahagian bawah halaman? Bagaimana untuk menggunakan JavaScript untuk mencapai kesan paparan kecerunan untuk memuatkan kandungan secara automatik selepas menatal ke bahagian bawah halaman? Oct 16, 2023 am 08:54 AM

Bagaimanakah JavaScript mencapai kesan paparan kecerunan untuk memuatkan kandungan secara automatik apabila menatal ke bahagian bawah halaman? Dalam reka bentuk web moden, menatal ke bahagian bawah halaman untuk memuatkan kandungan secara automatik adalah keperluan biasa. Untuk meningkatkan pengalaman pengguna, kesan paparan kecerunan juga merupakan pilihan reka bentuk biasa. Jadi, bagaimana kita melaksanakannya dalam JavaScript? Langkah pelaksanaan khusus dan contoh kod diberikan di bawah. Idea utama untuk mencapai kesan ini adalah untuk memantau acara tatal halaman dan menentukan sama ada bahagian bawah halaman telah dicapai berdasarkan kedudukan tatal.

See all articles