-
Notifications
You must be signed in to change notification settings - Fork 114
Dev.Front Module File.zh_cn
模块包都是放在usr/module
目录下的,基本目录结构如下:
{module name}/ ├── asset/ │ ├── css/ │ │ ├── front.css (模块前台样式) │ │ └── admin.css (模块后台样式) │ ├── js/ │ └── image/ ├── config/ │ ├── block.php (模块的区块) │ ├── module.php (模块相关信息) │ ├── navigation.php (模块前台,后台导航) │ └── page.php (模块页面[admin,front,feed]) ├── locale/ (模块翻译文件) ├── sql/ (模块sql文件) ├── src/ │ ├── Controller / │ │ ├── Admin (后台控制器) │ │ └── Front (前台控制器) │ ├── Form (模块表单) │ ├── Model (模块模型) │ └── Installer (模块安装) ├── template/ (翻译文件) │ ├── admin/ (后台模板) │ ├── block/ (区块模板) ` └── front/ (前台模板)
下面具体介绍模块包中的一些与前端相关的常用文件asset、config、sql、template。
Asset文件夹内主要放置模块的静态文件,如css和js文件。这个静态目录在安装的时候将会被发送到www/asset
目录下。
模块的css一般都需要包含2个css文件,front.css和admin.css,放在asset/css
目录下。为了避免模块样式跟主题样式冲突,模块的css文件名字都必须以模块名开头,如article模块的css文件命名为article-{name}.css。
front.css
/* Common */
.article-mb {
margin-bottom: 5px;
}
.article-mb-large {
margin-bottom: 10px;
}
.article-hr {
height: 0;
border-top: 1px dashed #d5d5d5;
}
...
/* List page */
.article-list-item {
}
.article-list-title {
}
.article-list-posttime {
}
...
/* Detail page */
.article-detail-title {
}
.article-detail-p {
}
...
/* Classify page */
.article-classify-item {
}
.article-classify-posttime {
}
/* Search page */
.article-search-item {
}
.article-search-title {
}
.article-search-time {
}
//以上命名规范参照这个形式
.{module name}-{page name}-{what} {
}
.{module name}-{block name}-{what} {
}
admin.css
一般情况下,模块的后台不需要写样式,使用默认的bootstrap即可,较复杂的后台则需要按前台规范来写。
/* Add page */
.tag-add-btn {
}
/* List page */
.tag-list-item {
}
...
一般情况下,都使用Backbone来书写js。包括Model和View两层即可。
Config文件夹主要用于存放模块的配置文件,目录下至少需要有一个module.php文件。
module.php定义了模块的基本信息以及制定要安装的其他配置文件,文件内容如下。
<? php
return array(
// Module meta
'meta' => array(
// required
'title' => 'DEMO Sandbox',
// Description, for admin, optional
'description' => 'Examples and tests for developers.',
// Version number, required
'version' => '0.0.0'
),
// Author information
'author' => array(
// Author full name, required
'name' => 'Taiwen Jiang',
// Email address, optional
'email' => '[email protected]',
// Website link, optional
'website' => 'http://www.xoopsengine.org',
// Credits and aknowledgement, optional
'credits' => 'Zend Framework Team; Pi Engine Team; EEFOCUS Team.'
),
// Module dependency: list of module directory names, optional
'dependency' => array(
),
// Maintenance actions
'maintenance' => array(
'resource' => array(
'database' => array(
'sqlfile' => 'sql/mysql.sql',
'schema' => array(
'learn' => 'table'
...
)
)
)
)
);
注意 :
- 开发模块的时候,可以先安装模块,在开发过程中,如果新增或修改了内容,涉及到配置文件的修改,比如增加一个区块,修改导航等,都要在后台 Operation->System->Modules->Installed 已安装列表点击对应模块的update操作,更改才能生效。如果是产品模式下,必须要修改了版本号才能update生效。
注意 :产品模式指var/config/engine.php
文件中'environment' => 'production'
- 新增了配置文件后需要在module.php中添加相应的属性,例如添加了navigation.php和block.php后,需要在module.php中添加如下代码。
<? php
return array(
···
'maintenance' => array(
'resource' => array(
'navigation' => 'navigation.php',
'block' => 'block.php'
···
)
)
);
navigation.php定义了模块导航中的项目以及其属性。
导航包括前后台导航,每个导航项的可选属性有label,route,controller,action,visible,pages。模块安装后,会在数据库的core_navigation_node表中生成对应的记录。
front
前台导航手动渲染方法:$this->navigation('{module name}-front',array(...))->render()
其他方法参照navigation。
注意 :模块前台导航会多一个uri属性,可以直接写成绝对路径。
admin
后台导航是自动在后台渲染,它是供模块后台管理程序的使用。管理某个模块的时候,程序会自动创建模块导航,需要注意的是后台界面上,只会显示一级导航。
<? php
return array(
'admin' => array(
'nav1' => array(
'label' => 'nav1',
'route' => 'admin',
'controller' => 'index',
'action' => 'index',
'pages' => array(
)
),
'nav2' => array(
'label' => 'nav2',
'visible' => 0,
...
)
),
'front' => array(
'frontnav1' => array(
'label' => 'frontnav1',
'uri' => 'http://www.eefocus.com/',
'target' => '_blank'
...
),
'frontnav2' => array(
'label' => 'frontnav2',
'route' => 'default',
'controller' => 'test',
'action' => 'test'
...
),
)
);
block.php定义了各个区块的属性,文件内容如下。
<? php
return array(
'block-a' => array(
'title' => __('document block a'), // __翻译函数
'description' => __('document block a'),
'render' => array('block', 'blocka'), // param : {class}, {method}
'template' => 'block-a' // template文件名,文件位置是在template/block/
),
'block-b' => array(
'title' => __('document block b'),
'description' => __('document block b'),
'render' => array('block', 'blockb'),
'template' => 'block-b',
'config' => array( // 后台区块配置
'config1' => array(
'title' => 'config1',
'description' => 'this config description',
'value' => 'value1'
),
'config2' => array(
'title' => 'config2',
'description' => 'this config description',
'edit' => 'checkbox',
'value' => 1
)
)
)
);
注意 :
- 区块名,在模块安装或者更新过后,会在表core_block中生成相关记录,在core_block中区块名是
{module name}-{block name}
,也就是说区块真正的名字是模块名+配置里面的名字。 - 区块配置,添加了config属性的区块,可以在后台 Setting->{module name}->Blocks->Edit 进行配置编辑。
config.php用于配置模块后台参数。
创建一个模块需要的表,并在module.php中配置sqlfile属性,如'sqlfile' => 'sql/mysql.sql'
。这样当安装模块的时候,程序会在安装成功后执行sql文件里面的语句。
schema属性则是配置在模块卸载的时候,需要删除的表(如果模块里已经有数据,注意备份已有的数据)。具体详情参照Module database,这里不具体描述。
template文件夹用于存放模板文件,包括前台、后台以及区块模板,这里定义的文件都是以phtml作为扩展名,文件可以HTML标签和PHP语言混写,用于生成HTML页面发送给浏览器。一般来说,每一个前后台模板都对应一个controller类里的action,每个区块模板对应一种区块。下面展示的是一个区块模板文件。
<h3 class="page-header"><?php echo $this->escape($block['caption']); ?></h3>
<p><?php echo $block['content']; ?></p>
<hr />
<h3><?php _e('The options: '); ?></h3>
<?php foreach ($block['options'] as $key => $value) { ?>
<div><span><?php echo $this->escape($key); ?></span><span><?php echo $this->escape($value); ?></span></div>
<?php } ?>