我写了自己的My.grid
继承自Ext.grid.Panel
并在itemdblclick
事件上设置了监听器。
此事件的处理程序函数将view
作为第一个参数,并以this
作为范围。
我不明白为什么我会在view
和this
中获得不同的值?
this
是My.grid
view
是Ext.grid.Panel
的一个实例(但我希望My.grid
)
可能我做错了什么?或者它是ExtJS的错误/特征?
如何编写继承的小部件view
引用继承的对象?
这是一个简单的例子:
<!DOCTYPE html>
<html>
<head>
<title>ExtJS Test page</title>
<link rel="stylesheet" href="http://cdn.sencha.io/ext-4.1.1-gpl/resources/css/ext-all-gray.css">
<script type="text/javascript" charset="utf-8" src="http://cdn.sencha.io/ext-4.1.1-gpl/ext-all.js"></script>
<script type="text/javascript">
Ext.create('Ext.data.Store', {
storeId: 'simpsonsStore',
fields: ['name', 'email', 'change'],
data: {
'items': [
{ 'name': 'Lisa', 'email': 'lisa@simpsons.com', 'change': 100 },
{ 'name': 'Bart', 'email': 'bart@simpsons.com', 'change': -20 },
{ 'name': 'Homer', 'email': 'home@simpsons.com', 'change': 23 },
{ 'name': 'Marge', 'email': 'marge@simpsons.com', 'change': -11 }
]
},
proxy: { type: 'memory', reader: { type: 'json', root: 'items' } }
});
Ext.define('MY.grid', {
extend: 'Ext.grid.Panel',
alias: 'widget.simpsonsgrid',
title: 'Simpsons',
store: Ext.data.StoreManager.lookup('simpsonsStore'),
columns: [
{ header: 'Name', dataIndex: 'name' },
{ header: 'Email', dataIndex: 'email' },
{ header: 'Change', dataIndex: 'change' }
],
initComponent: function () {
this.callParent(arguments);
this.on('itemdblclick', this.test, this);
},
test: function (view, record) {
console.log(this); // instance of My.grid
console.log(view); // instance of Ext.grid.Panel
}
});
Ext.onReady(function () {
Ext.widget('simpsonsgrid', {
renderTo: Ext.getBody()
});
});
</script>
</head> <body></body> </html>
答案 0 :(得分:1)
查看API(http://docs.sencha.com/ext-js/4-1/#!/api/Ext.grid.Panel)。您可以看到此特定事件具有以下签名:
itemdblclick(
Ext.view.View this,
Ext.data.Model record,
HTMLElement item,
Number index,
Ext.EventObject e,
Object eOpts
)
所以实际上你应该在Ext.grid.View
参数中获得view
的等值。您可以访问MY.grid
来获取view.ownerCt
的实例。