我正在编写一个 prestashop 模块。在安装功能中,我想创建一个后台选项卡来管理我的模块操作。是否可以使用 Prestashop 类而不直接在数据库中创建坏的?
问问题
6011 次
4 回答
5
Prestashop 有这样的课程。
这是 Tab 类,使用函数add
.
看:
$tab = new Tab();
$tab->class_name = 'your_class';
$tab->id_parent = 0;
$tab->module = 'Your module';
$tab->name[(int)(Configuration::get('PS_LANG_DEFAULT'))] = $this->l('Module name');
return $tab->add();
于 2013-04-16T13:45:00.490 回答
4
您不必在 admin/tab 中创建 admintap 文件
只下载这个模块,看看它是如何工作的 Prestashop Autoupgrade 模块
它是一个标准的 prestashop 模块,可以为自己创建新标签
于 2013-01-08T17:10:50.803 回答
1
是的,这是可能的,您可以为您的模块提供自己的选项卡或子选项卡,请查看以下文档:
唯一的问题是您必须在模块文件夹之外添加文件,并在后台手动添加选项卡...
于 2012-10-04T07:33:34.563 回答
1
是的,你可以做到。创建您的类object model
的表数据库并将您的类插入到表数据库tab
中。
例如我修改模块mymodule
文档 1.4 :
public function install()
{
if (parent::install() == false OR
!$this-registerHook('leftColumn') OR
!Db::getInstance()-Execute('
CREATE TABLE IF NOT EXISTS `'._DB_PREFIX_.'test` (
`id_test` int(6) NOT NULL AUTO_INCREMENT,
`test` varchar(255) NOT NULL,
PRIMARY KEY(`id_test`)
) ENGINE='._MYSQL_ENGINE_.' default CHARSET=utf8') OR
!$this-setTab()
)
return false;
return true;
}
public function setTab() {
if (!Db::getInstance()-Execute(
"INSERT INTO `"._DB_PREFIX_."tab`
(`class_name`, `position`, `id_parent`)
VALUES ('AdminTest', '10', '1')"
))
return false;
$id = Db::getInstance()-insert_id();
$count = (int)Db::getInstance()-getValue('SELECT COUNT(*) FROM '._DB_PREFIX_.'lang');
while ($count 0) {
if (!Db::getInstance()-Execute(
"INSERT INTO `"._DB_PREFIX_."tab_lang`
(`id_tab`, `id_lang`, `name`)
VALUES (".$id.", ". $count.", 'Test Tab')"
))
return false;
$count--;
}
if (!TabCore::initAccess($id))
return false;
return true;
}
尝试修改install
功能和添加setTab
功能。您可以为您的模块进行修改。
于 2012-10-25T13:15:34.997 回答