## 創建后臺菜單
菜單數據以數組形式定義,定義好之后可以通`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文件,如下圖

目前后臺內置的中英語言包、因此在上面講的$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目錄下,如下

~~~
<?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接口