我正在为magento开发一个自定义模块,用于列出员工。
我几乎找到了一切。我唯一剩下的就是如何突出显示所选的值。
我遇到的问题是后端。
我为每位员工提供了2个标签,一个用于员工数据,另一个标签用于magento类别。
1名员工可以拥有1个或更多类别。
存储类别的数据库表是非eav表。
所以我的问题是 多选中的内容决定选择哪些值?就像现在一样,只选择了一个值。
答案 0 :(得分:9)
我认为你可以通过简单地将要选择的id的数组传递到为_prepareForm()方法中的multiselect添加的字段的'value'属性来实现。如下所示。
$fieldset->addField('category_id', 'multiselect', array(
'name' => 'categories[]',
'label' => Mage::helper('cms')->__('Store View'),
'title' => Mage::helper('cms')->__('Store View'),
'required' => true,
'values' => Mage::getSingleton('mymodule/mymodel')->getMymodelValuesForForm(),
'value' => array(1,7,10),
));
表单元素的id(例如category_id)不能是模型中的属性,否则以后使用$ form-> setValues()设置表单值时,属性值将被覆盖。
我通常将多个选项存储为由逗号分隔的文本列,就像大多数magento模块处理存储一样,需要稍微不同的方法,如下所示。
在带有多选的选项卡的表单块中,首先在_prepareForm()方法中定义要显示的元素。然后,您可以从模型中获取值并将它们放入表单数据中。
protected function _prepareForm()
{
...
$fieldset->addField('store_id', 'multiselect', array(
'name' => 'stores[]',
'label' => Mage::helper('cms')->__('Store View'),
'title' => Mage::helper('cms')->__('Store View'),
'required' => true,
'values' => Mage::getSingleton('adminhtml/system_store')->getStoreValuesForForm(false, true),
));
...
if ( Mage::getSingleton('adminhtml/session')->getMymodelData() )
{
$data = Mage::getSingleton('adminhtml/session')->getMymodelData();
} elseif ( Mage::registry('mymodel_data') ) {
$data = Mage::registry('mymodel_data')->getData();
}
$data['store_id'] = isset($data['stores']) ? explode(',', $data['stores']) : array();
$form->setValues($data);
}
我通常将选定的商店(在您的情况下为类别)存储在主模型中作为文本列和逗号分隔的ID值,因此爆炸。
在用于编辑操作的控制器中,我将正在编辑的模型放入mage注册表中,以便我们可以在上面的步骤中加载它和它的值。
Mage::register('mymodel_data', $model);
答案 1 :(得分:3)
感谢您的回答。
这就是我的领域的样子:
$fieldset->addField('npn_CatID', 'multiselect', array(
'label' => Mage::helper('employeelist')->__('Kategori'),
'class' => 'required-entry',
'required' => true,
'name' => 'npn_CatID',
'values' => $data,
'value' => array(3,5)
));
npn_CatID是我的db中保存类别ID的值。 我试图更改名称和字段ID,但无法使其正常工作。 如果其字段ID如上所示,则选择一个值,并为所选员工插入最后一个
我的数据阵列看起来像
array(array('value' => '1', 'label' => 'USB'), array('value' => '2', 'label' => 'Memories'))