我使用自定义数据库中的字段URL添加了自定义网格列:
$this->addColumn('url', array(
'header' => Mage::helper('companymodule')->__('Has Website'),
'align' => 'left',
'index' => 'url',
'renderer' => new Company_Module_Block_Adminhtml_Module_Grid_Renderer_HasUrl(),
'type' => 'options',
'options' => Mage::getSingleton('companymodule/hasurl')->getOptionArray(),
));
并创建此自定义呈现:
class Company_Module_Block_Adminhtml_Module_Grid_Renderer_HasUrl extends Mage_Adminhtml_Block_Widget_Grid_Column_Renderer_Abstract
{
public function render(Varien_Object $row)
{
$value = trim((string)$row->getData($this->getColumn()->getIndex()));
if (empty($value)) {
return 'No';
} else {
return 'Yes';
}
}
}
以及过滤器dropdwon的自定义模型:
class Company_Module_Model_Hasurl extends Varien_Object
{
static public function getOptionArray()
{
return array(
'Yes' => Mage::helper('companymodule')->__('Yes'),
'No' => Mage::helper('companymodule')->__('No')
);
}
}
除非您尝试过滤,否则此方法效果很好。我认为它正在尝试将值“是”与$row->getData($this->getColumn()->getIndex())
(数据库表中的URL字段)的值进行匹配。但是,与匹配URL字段值本身不同,我基本上是在尝试进行过滤,((bool)empty($url))
以便用户可以根据是否该数据库条目是否具有URL。
如何为这样的过滤器创建自定义逻辑?
'renderer' => Company_Module_Block_Adminhtml_Module_Grid_Renderer_HasUrl