## 创建后台菜单
菜单数据以数组形式定义,定义好之后可以通`create_menu`函数手动创建菜单,通过`del_menu`函数来手动删除菜单。当然,除了以上方式还支持系统自动判断导入菜单,请参考下面的自动导入方式。
## 字段说明
<blockquote class="danger"><p>2.1.220220版本之前,字段需要填写完整</p></blockquote>
| 字段名 | 说明 | 默认值 | 是否必填 |
| --- | --- | --- | --- |
| parent_id | 父菜单ID或父菜单的name,默认0,表示最顶级 | 0 | - |
| title | 菜单名称,菜单多语言目前需要在admin_route后台路由事件中手动导入菜单语言包 | - | 必填 |
| name | 权限规则 | - | 必填 |
| route | 路由 | | - |
| icon| 图标 | fas fa-align-ustify/far fa-circle | - |
| remark | 备注 | | -|
| weigh | 排序 | 0 | - |
| type | 类型:0-权限规则,1-菜单,2-菜单头(提供的额外标识) | 1 | - |
| child | 子级菜单,有子级的话按一级菜单字段填写即可 | - | - |
1. name,权限规则
写法:控制器/方法,二级文件夹则是文件夹名/控制器/方法,注意二级需要填写路由
2. route,路由地址
写法:文件夹名.控制器/方法,常用于有文件夹的情况,注意是“点”
3. icon,图标
基于`fontawesome`,一级菜单默认为`fas fa-align-justify`,二级菜单默认`far fa-circle` 图标地址:<a href="https://fa5.dashgame.com/#/图标">https://fa5.dashgame.com/#/图标</a>
4. type,菜单类型
未填写`type`时系统会自动判断菜单类型,在认为有子级情况下认为是菜单。若有特殊情况,您需要填写`type`字段
## 自动导入示例
在插件名称类里面增加公共属性`$menu`,在安装时检测到有这个属性就会自动导入,另外在`卸载`、`启用`、`禁用`、`更新`等操作时系统会自动对菜单进行相应的操作,例如插件禁用,菜单也会被禁用。
> 注意:如果菜单已存在并且这个菜单不属于该插件就不会导入,如果已存在,属于该插件则是更新菜单。
> 插件升级操作时,同样会根据menu导入,如果存在则是更新该菜单,如有额外处理,可在upgrade方法中操作
~~~
<?php
declare (strict_types=1);
namespace addons\demo;
use think\Addons;
class Demo extends Addons
{
// 菜单
public $menu = [
[
'title'=>'插件测试',
'name'=>'demo',
'child'=>[
['title'=>'查看','name'=>'demo/index'],
['title'=>'添加','name'=>'demo/add'],
['title'=>'修改','name'=>'demo/edit'],
['title'=>'删除','name'=>'demo/del'],
]
]
];
public function install()
{
return true;
}
public function uninstall()
{
return true;
}
}
~~~
## 菜单多语言
在插件目录,在data目录下创建zh-cn.php文件,如下图
![](https://img.kancloud.cn/a1/45/a14511db706c16ac94ad71d4e4739bdc_212x111.png)
目前后台内置的中英语言包、因此在上面讲的$menu变量里面title全部写成英文,然后下面的写上英文跟中文的对照。
~~~
<?php
return [
'Addon test' => '插件測試'
];
~~~
支持其他语言包写法,例如繁体中文命名为:zh-tw.php,那么代码如下:
~~~
<?php
return [
'Addon test' => '插件測試'
];
~~~
创建文件后我们需要在插件初始化时加载语言包
~~~
public function addonsInitHook()
{
// 获取语言包对象
$lang = app()->lang;
// 加载语言包,$this->addon_path 插件目录,DIRECTORY_SEPARATOR 是 '/' 或 '\',$lang->getLangset() 是当前语言
$lang->load($this->addon_path.'data'.DIRECTORY_SEPARATOR.$lang->getLangset().'.php');
}
~~~
## 手动导入
如下,我们可以创建PHP文件,放到插件的data目录下,如下
![](https://img.kancloud.cn/32/5c/325c9630822f033e706715b5654217aa_294x148.png)
~~~
<?php
return [
[
// 父菜单ID或父菜单name或0
"parent_id" => 57,
// 标题
"title" => '菜单名称',
// 权限认证规则
"name"=>"createhtml",
// 路由地址
"route" => "",
// fontawesome 图标
"icon" => 'fas fa-print',
// 备注
"remark" => "",
// 排序
"weigh" => 10,
// 菜单类型
"type" => 1,
// 子级
"child"=>[
[
// 标题
"title" => '菜单名称1',
// 权限认证规则
"name"=>"createhtml/index1",
// 子级
"child"=>[
["title" => '菜单名称2',"name"=>"createhtml/index",]
]
],
[
// 标题
"title" => '菜单名称3',
// 权限认证规则
"name"=>"createhtml/index",
]
]
],
];
~~~
在安装的时候导入,使用`create_menu`方法导入。导入后无需管禁用、启用与卸载的操作了,系统会自动去操作菜单。
~~~
public function install()
{
// 菜单数组文件路径
$menu = include $this->addon_path.'data'.DIRECTORY_SEPARATOR.'menu.php';
// 参数一给路径,参数二给当前插件的标识
create_menu($menu,$this->getName());
return true;
}
~~~
## 方法的使用
- create_menu 创建菜单
参数1为菜单数组,参数2为菜单属于的插件标识。
> 注意:如果菜单已存在并且这个菜单不属于该插件就不会导入,如果已存在,属于该插件则是更新菜单
```
// 在插件里面可以直接获取到插件标识,当然你也可以直接写上你的插件标识
create_menu($menu, $this->getName());
```
- status_menu 更改状态:启用与禁用.
参数1为:1=启用,0=禁用,参数2为插件名称标识
~~~
status_menu(1, $this->getName()); // 启用菜单
~~~
~~~
// 例如插件叫demo
status_menu(0, 'demo'); // 禁用demo的菜单
~~~
- del_menu 删除菜单
~~~
// 参数1为插件标识
del_menu($name);
~~~
- 简介
- 下载与安装配置
- 下载
- 虚拟主机安装
- 虚拟主机必读
- 百度云虚拟主机
- 创业云虚拟主机
- Linux下宝塔安装
- 宝塔一键部署
- Windows下宝塔安装
- phpEnv下安装
- phpStudy下安装
- 伪静态(url重写)
- 安装系统
- 调试模式与env文件
- 重新安装与安装文件说明
- 后台使用帮助
- 后台入口文件
- 首页面板
- 配置中心
- 站点配置
- 邮件配置
- 附件配置
- 应用中心配置
- 前台URL规则配置
- SEO设置
- SEO设置-静态生成
- 文档属性
- 站点模块
- V2.2.2版本 -
- V2.2.3版本 +
- 模型管理
- 栏目管理
- 字段类型与组件
- 前言
- 前端组件
- 动态下拉(selectpage)
- 验证规则
- text 单行文本
- textarea 多行文本
- radio 单选
- checkbox 复选
- select 下拉列表
- selects下拉列表(多)
- selectpage 动态下拉
- editor编辑器
- image图片
- images图片(多)
- number数字
- date日期
- datetime日期和时间
- downfile文件上传
- downfiles文件上传(多)
- array 数组(键值对)
- 内容管理
- 自定义URL
- 多语言
- 界面多语言
- 内容多语言
- 多语言URL地址
- 附件管理
- 应用中心
- 标签语法
- 标签使用必读
- 列表标签
- content 内容列表标签
- contentpage 内容列表分页
- wfpage 瀑布流分页
- filter 筛选标签
- order 排序标签
- 内容标签
- guestbook 留言(表单)标签(废弃)
- form 表单标签
- pre 上一篇标签
- next 下一篇标签
- prenext 上一篇下一篇(高级)标签
- fileinfo 获取附件信息(文件下载)
- 内容分页
- raw 格式化编辑器文本(即将废弃)
- 全局标签
- seo 标签
- channel 栏目标签
- arcone 获取单条文档
- breadcrumb 面包屑导航标签
- adv 站点模块标签
- date 日期格式化标签
- substr字符(标题)截取标签
- volist 循环标签
- language 获取语言列表标签
- lang 特定语言下显示内容标签
- query 查询数据库内容
- include 导入模板文件标签
- 原生PHP与php标签
- map生成位置地图
- thumb 生成缩略图
- addons 插件检测
- 标签管理
- taglist标签(获取标签列表)
- tagarclist根据标签获取文章内容列表
- 导入标签
- 模板开发
- 1. 创建模板
- 2. 模板目录结构
- 3. 模板描述文件(重要) info.ini
- 4. 变量输出格式
- 4. 模板变量
- 5. 获取站点配置
- 6. 模板界面多语言
- 7. 模板静态目录及调用静态文件
- 8. 模板定义插件事件
- 9. 模板搜索页
- 10. 模板配置JSON
- 11. 导入演示数据
- 12. 卸载删除演示数据
- 13. 模板文件打包
- 14. 整站源码打包
- 插件开发
- 1. 创建插件
- 2. 目录结构
- 3. 插件名称类
- 4. 插件信息(info.ini)
- 5. 插件事件
- 6. 配置文件
- 7. install 安装目录
- 8. 创建菜单
- 9. 插件控制器
- 10. 插件视图
- 10-1 插件主题化
- 11. 插件模型
- 12. 模型事件(已废弃)
- 13. 插件内置函数
- 13-1 插件函数库
- 14. 插件多语言
- 15. 插件中间件
- 16. 插件路由
- 17. 插件验证器
- 18. 标签库
- 19. 第三方类库
- 20. 数据库文件导入
- 插件打包
- 后台前端使用帮助
- 二次开发帮助(更新中)
- 后台前端开发帮助
- 路由(链接地址、访问规则)
- URL访问
- 路由定义
- URL生成
- 会员管理
- 前台限制页面登录或权限控制
- 附录
- 数据字典
- 助手函数库
- API接口