英文原文:http://magento.stackexchange.com/questions/5973/adding-columns-to-customer-grid-using-observer-or-overriding-the-customer-grid
为了给用户grid新增一个column,需要重写block:Mage_Adminhtml_Block_Customer_Grid
,并覆写block里的两个方法:
- _prepareCollection:添加你的属性到collection中
- _prepareColumns:添加column到grid中
新建模块并配置
先新建一个模块Easylife_Customer
,修改
true
local
```
# 修改配置文件
``` xml app/code/local/Easylife/Customer/etc/config.xml
0.0.1
Easylife_Customer_Block_Adminhtml_Customer_Grid
编辑block文件
addNameToSelect()
->addAttributeToSelect('email')
->addAttributeToSelect('created_at')
->addAttributeToSelect('group_id')
//如果你要添加的属性是用户自身的属性,那么用下面的语句
->addAttributeToSelect('mobile')
//如果你要添加的属性是用户地址表中的,参考下面的语句
//->joinAttribute('mobile', 'customer_address/mobile', 'default_billing', null, 'left')
->joinAttribute('billing_postcode', 'customer_address/postcode', 'default_billing', null, 'left')
->joinAttribute('billing_city', 'customer_address/city', 'default_billing', null, 'left')
->joinAttribute('billing_telephone', 'customer_address/telephone', 'default_billing', null, 'left')
->joinAttribute('billing_region', 'customer_address/region', 'default_billing', null, 'left')
->joinAttribute('billing_country_id', 'customer_address/country_id', 'default_billing', null, 'left');
$this->setCollection($collection);
//下面是替换了原有的parent::_prepareCollection的代码,原有的代码是调用了Mage_Adminhtml_Block_Customer_Grid的父类即Mage_Adminhtml_Block_Widget_Grid中的代码
//直接调用 parent::_prepareCollection 会使得上面的代码失效。
//而你又不能用这种语法来调用父类的父类的方法 parent::parent::_prepareCollection(),所以就只能将代码整个copy到此处
if ($this->getCollection()) {
$this->_preparePage();
$columnId = $this->getParam($this->getVarNameSort(), $this->_defaultSort);
$dir = $this->getParam($this->getVarNameDir(), $this->_defaultDir);
$filter = $this->getParam($this->getVarNameFilter(), null);
if (is_null($filter)) {
$filter = $this->_defaultFilter;
}
if (is_string($filter)) {
$data = $this->helper('adminhtml')->prepareFilterString($filter);
$this->_setFilterValues($data);
}
else if ($filter && is_array($filter)) {
$this->_setFilterValues($filter);
}
else if(0 !== sizeof($this->_defaultFilter)) {
$this->_setFilterValues($this->_defaultFilter);
}
if (isset($this->_columns[$columnId]) && $this->_columns[$columnId]->getIndex()) {
$dir = (strtolower($dir)=='desc') ? 'desc' : 'asc';
$this->_columns[$columnId]->setDir($dir);
$this->_setCollectionOrder($this->_columns[$columnId]);
}
if (!$this->_isExport) {
$this->getCollection()->load();
$this->_afterLoadCollection();
}
}
return $this;
}
/**
* 覆写_prepareColumns方法在email列后面新增一列
* 如果你想要改变新增列的位置,那么直接修改addColumnAfter方法的第三个参数就好了
*/
protected function _prepareColumns(){
$this->addColumnAfter('mobile', array(
'header' => Mage::helper('customer')->__('Mobile'),
'index' => 'mobile'
),'email');
return parent::_prepareColumns();
}
}