Joomla子窗体字段



我们继承了一个Joomla项目,需要为产品图片实现一个重复字段。

我们在理解如何在数据库中实现这一点时遇到了麻烦。是否有一些命名约定来告诉Joomla使用什么表/外键?

我们在 xml 文件中有这个:

<?xml version="1.0" encoding="UTF-8"?>
<field
name="gallery_images"
type="subform"
label="Gallery Images"
description="Images for the gallery"
multiple="true"
min="1"
max="10"
>
<form>
<field
name="image_url"
type="media"
label="Image"
/>
</form>
</field>

然后我们将被拉入表单编辑.php文件,如下所示:

<div class="control-group">
<div class="control-label"><?php echo $this->form->getLabel('gallery_images'); ?></div>
<div class="controls"><?php echo $this->form->getInput('gallery_images'); ?></div>
</div>

这实际上在后端都完美运行。但它不会在任何地方保存任何东西。我们尝试在产品表上创建一个字段,认为它可能会存储为 JSON。我们尝试为图像创建另一个带有product_id的表,认为也许 Joomla 只是计算出外键?

Joomla文档似乎没有说明它在数据库中的工作方式。(https://docs.joomla.org/Subform_form_field_type(

提前谢谢。

因此,由于 joomla 保存了 gallery_images 字段,因此我们编写了一些代码来手动执行此操作。

class ModelProduct extends JModelAdmin
{
public function save($data) {
if (parent::save($data)) {
$registry = new Registry;
$registry->loadArray($data['gallery_image']);
$data['gallery_image'] = (string) $registry;
$db = JFactory::getDbo();
$query = $db->getQuery(true);
// Fields to update.
$fields = array(
$db->quoteName('gallery_image') . ' = ' . $db->quote($data['gallery_image']),
);
// Conditions for which records should be updated.
$conditions = array(
$db->quoteName('id') . ' = '.$data['id'],
);
$query->update($db->quoteName('v4yn2_product'))->set($fields)->where($conditions);
$db->setQuery($query);
$result = $db->execute();
return true;
}
return false;
}
}

最新更新