shofiul / laravel-menu
类似于WordPress的Laravel 5拖放式菜单生成器
v1.1.0
2019-12-24 10:53 UTC
Requires
- php: >=5.4.0
- illuminate/support: 6.*
This package is auto-updated.
Last update: 2024-09-24 22:20:17 UTC
README
遵循 https://github.com/harimayco/wmenu-builder 仓库
Laravel拖放式菜单编辑器,类似于WordPress
从 https://github.com/lordmacu/wmenu 分支
安装
- 运行
composer require harimayco/laravel-menu
如果使用Laravel 5.5,步骤2和3是可选的
- 在config/app.php文件中的"providers"数组中添加以下类(在Laravel 5.5中为可选)
Harimayco\Menu\MenuServiceProvider::class,
- 在config/app.php文件中添加外观(在Laravel 5.5中为可选)
'Menu' => Harimayco\Menu\Facades\Menu::class,
- 运行发布
php artisan vendor:publish --provider="Harimayco\Menu\MenuServiceProvider"
- 在 config/menu.php 中配置(可选)
- 自定义中间件:您可以添加自己的中间件
- 表前缀:默认情况下,此包将创建两个新表,分别命名为"menus"和"menu_items",但您仍然可以添加自己的表前缀,避免与现有表冲突
- 表名称:如果您想使用特定的表名称,您必须修改这些表和迁移
- 自定义路由:如果您想编辑路由路径,您可以编辑该字段
- 角色访问:如果您想在菜单项上启用角色(权限)
- 运行迁移
php artisan migrate
完成
菜单构建器使用示例 - 显示构建器
在您的视图blade文件中
@extends('app') @section('contents') {!! Menu::render() !!} @endsection //YOU MUST HAVE JQUERY LOADED BEFORE menu scripts @push('scripts') {!! Menu::scripts() !!} @endpush
通过菜单ID获取菜单项
use Harimayco\Menu\Facades\Menu; ... /* Parameter: Menu ID Return: Array */ $menuList = Menu::get(1);
通过菜单名称获取菜单项
在这个示例中,您必须有一个名为 Admin 的菜单
use Harimayco\Menu\Facades\Menu; ... /* Parameter: Menu ID Return: Array */ $menuList = Menu::getByName('Admin');
使用模型
调用模型类
use Harimayco\Menu\Models\Menus; use Harimayco\Menu\Models\MenuItems;
菜单使用示例(a)
一个基本的二级菜单可以在您的blade模板中显示
// Used to get the menu items into the blade template $public_menu = Menu::getByName('Public');
菜单使用示例(b)
现在在您的blade模板文件中,使用以下简单示例放置菜单
<div class="nav-wrap"> <div class="btn-menu"> <span></span> </div><!-- //mobile menu button --> <nav id="mainnav" class="mainnav"> @if($public_menu) <ul class="menu"> @foreach($public_menu as $menu) <li class=""> <a href="{{ $menu['link'] }}" title="">{{ $menu['label'] }}</a> @if( $menu['child'] ) <ul class="sub-menu"> @foreach( $menu['child'] as $child ) <li class=""><a href="{{ $child['link'] }}" title="">{{ $child['label'] }}</a></li> @endforeach </ul><!-- /.sub-menu --> @endif </li> @endforeach @endif </ul><!-- /.menu --> </nav><!-- /#mainnav --> </div><!-- /.nav-wrap -->
定制
您可以在 resources/views/vendor/wmenu/menu-html.blade.php 中编辑菜单界面
鸣谢
- wmenu laravel包,菜单类似于WordPress
兼容性
- 在laravel 5.2、5.3、5.4、5.5、5.6、5.7上进行了测试