如何处理 ExtJs 中的异常“无法调用方法 getRange of null”
How can I handle the exception "cannot call method getRange of null" in ExtJs?
我在网上搜索了答案,但没有找到任何东西。希望你能帮到忙。所以我对extJs
是相对新手.我在左侧有一个导航栏。当我按下那里的第一个按钮时,会打开一个新窗口,其中包含一个表并自动加载其数据。第一次它工作得很好,但是当我关闭窗口并再次打开它时,我收到错误"无法调用方法getRange of null"。
如果我打开第二个窗口(当我单击导航栏中的另一个按钮时(,我有 4 个选项卡,每个选项卡包含一个表格。每个选项卡都有一个带有按钮(创建、更改等(的工具栏。这里发生的事情与第一个窗口相同。我也可以将这些表打印为列表,第一次工作正常,但是当我取消打印操作时,我再次收到错误。
我确保所有按钮和表格都有不同的引用,所以我真的不知道这可能是什么。
有什么想法吗?
我添加我的面板,这将在此处打开新窗口:
items: [
{
xtype: 'tabpanel',
region: 'center',
items: [{
// 1. Tab
xtype: 'componentTap-panel',
title: UMA.Locale.rm.component.componentTitle,
id: 'componentTab'
}, {
// 2. Tab
title: UMA.Locale.rm.componentGroup.componentGroupTitle,
xtype: 'componentGroupTap-panel',
id: 'componentGroupTab'
}, {
// 3. Tab
title: UMA.Locale.rm.componentTemplateTitle,
xtype: 'componentTamplate-panel',
id: 'componentTemplateTab'
},
{
//4.Tab
title: UMA.Locale.rm.inventoryTitle,
xtype: 'inventoryTab-panel',
id: 'inventoryTab'
}
]
}
]
当窗口打开时,我添加我的表格和工具栏:
items: [{
xtype: 'toolbar',
region: 'north',
reference: 'componentToolbar',
items: [{
text: UMA.Locale.rm.buttonCreate,
action: 'createComp'
}, {
text: UMA.Locale.rm.buttonChange,
action: 'changeComp'
}, {
text: UMA.Locale.rm.buttonMove,
action: 'moveComp'
}, {
text: UMA.Locale.rm.buttonDelete,
action: 'deleteComp'
},{
text: UMA.Locale.rm.buttonPrint,
action: 'print',
margin: {
left: 8
}, {
xtype: 'componentTable-panel',
region: 'center'
}, {
xtype: 'componentsFilter-panel',
width: 300,
region: 'east'
}]
然后自动加载我的表:
items:[{
xtype: 'filtergrid',
reference: 'componentGrid',
paging: true,
hideHeaders: false,
region: 'center',
selModel: new Ext.selection.RowModel({
mode: "MULTI"
}),
store: {
model: 'Component',
autoLoad: true
},
columns: [{ ...
正如谢尔盖·诺维科夫(Sergey Novikov(所提到的,getRange()
是一种存储方法。我的网格商店也遇到了同样的错误,经过一次又一次的审查,我发现每当我关闭选项卡并再次重新打开它时,我都会得到网格视图的两个实例(可以通过grid.getView()
检查(,然后我得出的结论是,每当网格第二次创建时,网格视图的选择模型有两个实例,因为我正在使用selModel
代码为new Ext.selection.CheckboxModel({
showHeaderCheckbox: true,
width: 50,
mode: 'MULTI'
})
然后我将selModel
的代码更改为
selModel: {
selType: 'checkboxmodel',
showHeaderCheckbox: true,
width: 50,
mode: 'MULTI'
}
错误对我来说消失了。希望这对您有所帮助。:)
使用 Object()
构造函数测试对象是否为以下三种子类型之一:
- 空对象 对象
- 对象
- 数组对象
例如:
function foo() { return {"hi":"bye" } }
function bar() { return null }
function baz() { return [1,2,3] }
function testObject(myObject)
{
if (Object(myObject).hasOwnProperty("0") )
{
/* Call getRange */
return 'yes';
}
else
{
/* throw an exception */
return 'no';
}
}
console.log(testObject(foo()), testObject(bar()), testObject(baz()) );
- 未捕获错误:无法在初始化之前调用方法;
- 通过ajax从客户端调用C#方法来执行C#方法
- 如何避免在angular上多次调用方法;s ng重复
- React路由器错误-'无法调用方法'getRouteAtDepth'的未定义'
- 从window.onbeforeunload调用方法背后的代码
- 当输入字段为空时,如何在angular中调用方法
- 函数调用方法有什么用
- 多次调用方法后返回相同promise的模式
- 当从Chrome扩展动态注入JS时,从onload()内部调用方法
- 茉莉花 - 未调用方法
- jQuery如何在原型中调用方法
- ng显示“;调用方法“;不起作用
- Odoo销售点如何访问模型并使用JS调用方法
- 从React调用方法.JS州
- TinyMCE验证给出错误:无法调用方法'getContent'的未定义
- 向模板实例变量传递调用方法调用的结果时出现异常
- 如何在对象中调用方法
- 检查对话框是否为 Open 会引发“初始化前无法在对话框上调用方法”错误
- 在输入类型提交按钮上调用 C# 方法
- 通过类选择器单独调用方法