extjs grid取到数据而不显示的解决_extjs
找了快1个小时,就是不知道错误在哪里。。。郁闷
我在鼠标左侧点击tree节点,在右侧创建一个标签页,这个已经能够实现,于是我再在新建的标签页里嵌套一个Grid。
奇怪的问题出现了。。
FF和IE下都没报错。但是Grid就是不显示。本来我以为我代码错误。于是我狂找我的代码问题,无意中关掉FF的firbug插件界面,grid就现实出来了。。。原来只要我的窗口发生任何变化Grid才会显示出来。
请问这是我代码问题还是bug?如何解决?
补充一下,我直接在TabPanel里面用items管理grid对象并没问题。但是我用添加事件后在其中管理就出问题了。
文件都是封装在类包里面的。所以只贴关键部分
这是监听事件。
Java代码
listeners:{
'click':function(node, event) {
event.stopEvent();
//把根节点的选择判断去除
if(node.text=="SamPeng" || node.text == "文章管理" || node.text == "产品管理" || node.text == "信息管理" || node.text == "来访管理"){
}else{
var n = main.getComponent(node.id);
if (!n) { //判断是否已经打开该面板
//如果是按的文章列表,新建一个列表对象并且丢进新的标签页
if(node.text == "文章列表"){
var grid=new SamPeng.account.list();
n = main.add({
'id':node.id,
'title':node.text,
items: [{layout:"fit",items:grid}]
});}
}
main.setActiveTab(n);
}
}
listeners:{
'click':function(node, event) {
event.stopEvent();
//把根节点的选择判断去除
if(node.text=="SamPeng" || node.text == "文章管理" || node.text == "产品管理" || node.text == "信息管理" || node.text == "来访管理"){
}else{
var n = main.getComponent(node.id);
if (!n) { //判断是否已经打开该面板
//如果是按的文章列表,新建一个列表对象并且丢进新的标签页
if(node.text == "文章列表"){
var grid=new SamPeng.account.list();
n = main.add({
'id':node.id,
'title':node.text,
items: [{layout:"fit",items:grid}]
});}
}
main.setActiveTab(n);
}
}
然后是我的tab面板创建类
Java代码
* Copyright(c) 2008-2010, SamPeng Inc.
*/
package("SamPeng.panel");
/**
* 作用: 用来创建中间的主显示面板
* 作者:SamPeng
* 时间:2008年9月24日1:24:42
*/
SamPeng.panel.main = function(config){
var config=config || {};
var deconfig={
renderTo:'mainlay',
width:1000,
height:561,
activeTab:0,
plain: true,
border: true,
tabPosition: 'top',
frame: true,
autoScroll: true,
enableTabScroll:true,//超过宽度就自动两边多出滚动条
items:[{
title:"首页"
}
]
}
Ext.applyIf(config,deconfig);
SamPeng.panel.main.superclass.constructor.call(this,config);
}
Ext.extend(SamPeng.panel.main,Ext.TabPanel);
* Copyright(c) 2008-2010, SamPeng Inc.
*/
package("SamPeng.panel");
/**
* 作用: 用来创建中间的主显示面板
* 作者:SamPeng
* 时间:2008年9月24日1:24:42
*/
SamPeng.panel.main = function(config){
var config=config || {};
var deconfig={
renderTo:'mainlay',
width:1000,
height:561,
activeTab:0,
plain: true,
border: true,
tabPosition: 'top',
frame: true,
autoScroll: true,
enableTabScroll:true,//超过宽度就自动两边多出滚动条
items:[{
title:"首页"
}
]
}
Ext.applyIf(config,deconfig);
SamPeng.panel.main.superclass.constructor.call(this,config);
}
Ext.extend(SamPeng.panel.main,Ext.TabPanel);
Grid的就只贴数据源和属性的了。
Java代码
/*******************************************************
* 为表格建立数据源
* 链接后台,并且按每一页的数据列表返回
* 用Json数据格式传递
*******************************************************/
this.dataStore = new Ext.data.Store({
proxy: new Ext.data.HttpProxy({
url: 'php/article_list.php',
disableCaching:false
}),
reader: new Ext.data.JsonReader({
root: 'results',
totalProperty: 'total',
id:'id'
},[
{name: 'id'},
{name: 'name'},
{name: 'typename'},
{name: 'time'},
])
});
this.dataStore.load({params:{start:0, limit:this.myPageSize}});
。。。
。。。省略很多
。。。
/*******************************************************
* 构造编辑列表面板(GridPanel)
*******************************************************/
SamPeng.account.list.superclass.constructor.call(this, {
id: 'list-account-panel',
ds: this.dataStore,
cm: art_cm,
sm: selectBoxModel,
height:500,
tbar: pagingbar,
bbar: menubar,
loadMask: {msg: '读取数据中 ...'},
enableColumnHide: false,
autoScroll:true
//region:'center'
});
Ext.extend(SamPeng.account.list, Ext.grid.GridPanel, {
reload : function() {
this.dataStore.load({params:{start:0, limit:this.myPageSize}});
},
// 调用删除数据
// 服务器通过接受参数返回删除的数据
deleteData : function (jsonData) {
this.dataStore.load({params:{start:0, limit:this.myPageSize, delData:jsonData}});
}
/*******************************************************
* 为表格建立数据源
* 链接后台,并且按每一页的数据列表返回
* 用Json数据格式传递
*******************************************************/
this.dataStore = new Ext.data.Store({
proxy: new Ext.data.HttpProxy({
url: 'php/article_list.php',
disableCaching:false
}),
reader: new Ext.data.JsonReader({
root: 'results',
totalProperty: 'total',
id:'id'
},[
{name: 'id'},
{name: 'name'},
{name: 'typename'},
{name: 'time'},
])
});
this.dataStore.load({params:{start:0, limit:this.myPageSize}});
。。。
。。。省略很多
。。。
/*******************************************************
* 构造编辑列表面板(GridPanel)
*******************************************************/
SamPeng.account.list.superclass.constructor.call(this, {
id: 'list-account-panel',
ds: this.dataStore,
cm: art_cm,
sm: selectBoxModel,
height:500,
tbar: pagingbar,
bbar: menubar,
loadMask: {msg: '读取数据中 ...'},
enableColumnHide: false,
autoScroll:true
//region:'center'
});
Ext.extend(SamPeng.account.list, Ext.grid.GridPanel, {
reload : function() {
this.dataStore.load({params:{start:0, limit:this.myPageSize}});
},
// 调用删除数据
// 服务器通过接受参数返回删除的数据
deleteData : function (jsonData) {
this.dataStore.load({params:{start:0, limit:this.myPageSize, delData:jsonData}});
}
谢谢各位大侠了!
问题状况是我浏览器不动,Grid死活不显示,浏览器一变,Grid就出来了。而且是按照我设定的参数大小显示的。不明白倒底问题出在哪里。只有这么多分了。望指教
本来以为是代码有问题,看Firebug没有报错,并且观察Firebug确实从服务端取得了数据。搞了很久没有想出问题,但是什么也不干,把窗口最小化再最大化的时候,数据又出来了!!!
这可能是Extjs的一个Bug,从网上找类似的解决方法,找到了这个:
,后来又和qiuye402大侠进行了沟通终于搞定。
其实就是布局刷新的问题,只需将最外层的容器重新render一下就可以了。最外层的容器一般就是类似于viewport的东东了,刚开始不知道,一直重新render包含grid的panel,没有效果,重新render viewport一切OK了!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

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

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Dalam temu bual bahagian hadapan, kami sering ditanya bagaimana untuk melaksanakan susun atur dadu/mahjong menggunakan CSS. Artikel berikut akan memperkenalkan anda kepada kaedah menggunakan CSS untuk mencipta dadu 3D (lentur dan susun atur Grid untuk melaksanakan dadu 3D, saya harap ia akan membantu anda!

Apabila kita melihat gambar, kita hanya perlu melihat secara kasar lakaran kecil setiap gambar dalam folder, supaya kita boleh menyemak imbas atau mencari gambar yang kita perlukan dengan cepat. Walau bagaimanapun, kadangkala imej kecil imej tidak dipaparkan Ia mungkin disebabkan oleh tetapan atau memori yang tidak mencukupi. Penyelesaian untuk lakaran kecil gambar win7 tidak memaparkan Kaedah 1: 1. Mula-mula, pilih "Atur" di sudut kiri atas folder, dan kemudian klik "Folder dan Pilihan Carian". 2. Nyahtanda "Sentiasa tunjukkan ikon, jangan sekali-kali imej kecil" dan klik OK. Kaedah 2: 1. Periksa dahulu sama ada pemacu C anda masih mempunyai ruang yang mencukupi, sekurang-kurangnya 1GB atau lebih. 2. Jika tidak, klik kanan pemacu C dan pilih Properties, kemudian klik "Disk Cleanup" dalam "General". 3.

Ramai pelajar sering gagal memaparkan pemacu kilat USB seperti biasa apabila menggunakannya, sebaliknya, mereka mencabutnya secara langsung, menyebabkan huruf pemacu tidak dipaparkan sudut kiri bawah desktop dan pilih nombor satu daripada dua pilihan tetapan. Langkah 2: Pilih pilihan peranti. Langkah 3: Cari peranti lain dan cari ikon pemacu kilat USB Jika anda tidak mengenalinya, jangan panik hanya kekal pada antara muka ini dan anda boleh mencarinya dengan memasang pemacu denyar USB. Langkah 4: Padam peranti daripada ikon pemacu kilat USB yang berdiri sendiri, dan palamkan pemacu kilat USB sekali lagi dan huruf pemacu akan dipaparkan. Jika ia membantu anda, sila suka dan galakkan saya untuk menyelesaikan lebih banyak masalah komputer untuk anda. Ini ialah artikel yang dikemas kini oleh versi percubaan pengemaskini artikel kumpulan stesen Shuimiao·dedeCMS, jadi ia mempunyai tanda ini (2023-02-0617:27:18)

Semua fail dan sampah yang tidak berguna pada komputer disimpan dalam tong kitar semula Ramai pengguna mendapati tong kitar semula mereka telah hilang selepas mengemas kini sistem win11, mengakibatkan ketidakupayaan untuk memulihkan fail yang diperlukan Atas sebab ini, kami akan membawanya kepada anda hari ini datang dan ketahui cara menyelesaikan masalah Win11 tidak memaparkan Tong Kitar Semula. Apa yang perlu dilakukan jika Tong Kitar Semula tidak dipaparkan dalam Windows 11 1. Pertama, klik kanan tetikus pada kawasan kosong desktop dan pilih pilihan "Peribadikan" dalam menu pop timbul. 2. Selepas pemilihan, antara muka tetapan akan muncul Cari pilihan tema di sebelah kiri antara muka tetapan dan klik padanya. 3. Selepas mengklik, tatal ke bawah di sebelah kanan untuk mencari dan klik pilihan "Tetapan Ikon Desktop". 4. Selepas mengklik, anda boleh melihat antara muka pemilihan tong kitar semula. 5. Semak Tong Kitar Semula dan klik OK untuk memulakan semula

Rangka kerja susun atur CSS: Terokai lima rangka kerja susun atur yang biasa digunakan Pengenalan: Dalam reka bentuk web, reka letak adalah bahagian yang penting. Rangka kerja reka letak CSS boleh membantu kami membina halaman web dengan cepat dengan gaya reka letak yang berbeza. Artikel ini akan memperkenalkan lima rangka kerja reka letak CSS yang biasa digunakan dan menyediakan contoh kod khusus untuk membantu pembaca memahami dan menggunakan rangka kerja ini dengan lebih baik. 1. Bootstrap: Bootstrap ialah salah satu rangka kerja susun atur CSS yang paling popular pada masa ini. Ia mempunyai komponen yang kaya dan ciri responsif yang berkuasa yang boleh

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

Penjelasan terperinci tentang sifat susun atur relatif CSS: kedudukan dan relatif Dalam pembangunan bahagian hadapan, reka letak selalunya menjadi masalah yang perlu dihadapi oleh pembangun Untuk mengawal kedudukan elemen pada halaman dengan lebih baik, CSS menyediakan pelbagai kaedah reka letak. Antaranya, reka letak relatif adalah kaedah susun atur yang sangat biasa Dengan menggunakan kedudukan dan atribut relatif, kita boleh melaraskan kedudukan dan saiz elemen secara fleksibel. Atribut kedudukan digunakan untuk menentukan kaedah penentududukan nilai biasa

Sifat susun atur panel CSS: grid dan grid-template-lajur Dalam reka letak halaman web moden, reka letak panel ialah kaedah reka bentuk biasa yang boleh mengatur kandungan web dalam grid. Atribut susun atur grid dalam CSS dan atribut grid-template-columns adalah kunci untuk merealisasikan reka letak panel. 1. Pengenalan kepada atribut susun atur grid Atribut susun atur grid ialah atribut yang digunakan untuk mencipta susun atur grid dalam CSS Dengan menukar HTML
