添加Joomla!文章的自定义字段

时间:2018-11-06 17:18:35

标签: php joomla joomla-jtable

Joomla已有一段时间了!提供了将自定义字段添加到文章中的可能性。

现在,我想通过Joomla创建新文章! Api,使用以下代码(在Joomla!文档中也使用过)可以正常工作:

$article = JTable::getInstance( 'content' );

// create article entity object
$article->title             = $title;
$article->alias             = JFilterOutput::stringURLSafe( $title );
$article->fulltext          = $imagesHTML;
$article->images            = json_encode($image);
$article->catid             = $paramsArray['category_sun'];
$article->created           = JFactory::getDate()->toSQL();;
$article->created_by        = $paramsArray['user_author'];
$article->access            = 1;
$article->metadata          = '{"page_title":"","author":"","robots":""}';
$article->language          = '*';
$article->state             = 1;

// validate article
if (!$article->check()) {
    JError::raiseNotice( 500, $article->getError() );
    return false;
}
// store article into database
if (!$article->store(true)) {
    JError::raiseNotice( 500, $article->getError() );
    return false;
}

但是现在我还要添加自定义字段值吗?我怎么做?不幸的是,Joomla!文档没有说明这一点(并且已经过时)。

1 个答案:

答案 0 :(得分:0)

我找到了使用Joomlas Dbo进行数据库查询的方法:

$field = new stdClass();
$field->field_id = 1;
$field->item_id = $article->id;
$field->value = "2018-11-06";

$result = JFactory::getDbo()->insertObject('#__fields_values', $field);

首先,您必须创建一个新的字段对象,并使用insertObject方法存储它。存储自定义字段值的数据库表称为[prefix]_fields_values