我正在开发一个 Joomla 模块,该模块具有一个带有扩展 JFormField 类的自定义字段的表单。我想用这个表单来显示一个数据库记录并让用户修改保存的数据。我创建了自定义字段来显示基于外部数据库表的列表。一切正常,除了我无法预设自定义字段的值以在数据库中显示该值。我尝试了两种方法,但似乎都没有奏效:
1:
$form->setFieldAttribute('orderstatus', 'default', '1', $group = null);
2:
$form->setValue('orderstatus','main','1');
有什么建议吗?非常感谢!
mod_ngtourdetails.php:
$filepath = dirname(__FILE__) . '/tourDetailsForm.xml';
$form=new JForm('mod_gngtourdetails');
$form->loadFile($filepath);
ModGngTourDetailsHelper::preFillForm($form, $tourDetails);
tourDetailsForm.xml
<form>
<fields name="main">
<fieldset name="basic" addfieldpath="/modules/mod_gngtourdetails/models/fields">
<field
name="ID"
type="text"
label="ID"
description="ID"
size="10"
maxlenght="10"
/>
<field
name="orderstatus"
type="orderstatus"
label="Order Status"
description="Order Status"
/>
订单状态.php
class JFormFieldOrderStatus extends JFormField {
protected $type = 'orderstatus';
function getDB() {
...
return $db;
}
public function getInput() {
$db = JFormFieldOrderStatus::getDB();
$query = $db->getQuery(true);
$query->select($db->qn('ORDER_STATUS.NAME','NAME'));
$query->select($db->qn('ORDER_STATUS.ID','ID'));
$query->from($db->qn('ORDER_STATUS'));
$query->order('ORDER_STATUS.NAME ASC');
$rows = $db->setQuery($query)->loadObjectlist();
$result = '<select id="'.$this->id.'" name="'.$this->name.'">';
foreach($rows as $row){
$result .= '<option value="' . $row->ID .'" >' . $row->NAME . '</option>';
}
$result .= '</select>';
return $result;
}
}