mykholy/laravel-menu

此包最新版本(dev-main)没有提供许可证信息。

类似WordPress的Laravel 5拖放式菜单生成器

安装: 2

依赖者: 0

建议者: 0

安全: 0

星标: 1

关注者: 1

分叉: 0

开放问题: 0

语言:JavaScript

dev-main 2023-09-16 14:46 UTC

This package is auto-updated.

Last update: 2024-09-16 17:09:24 UTC


README

**此包已被废弃:我不再维护此包,如果您想接管此项目或自由分叉并创建自己的版本,请与我联系。谢谢**

Latest Stable Version Latest Unstable Version Total Downloads Monthly Downloads

https://github.com/lordmacu/wmenu 分支 Laravel拖放式菜单

安装

  1. 运行
composer require mykholy/laravel-menu

如果使用laravel 5.5,步骤2和3是可选的

  1. 将以下类添加到config/app.php文件中的"providers"数组中(laravel 5.5可选)
Mykholy\Menu\MenuServiceProvider::class,
  1. 在config/app.php文件中添加外观(laravel 5.5可选)
'Menu' => Mykholy\Menu\Facades\Menu::class,
  1. 运行发布
php artisan vendor:publish --provider="Mykholy\Menu\MenuServiceProvider"
  1. config/menu.php中配置(可选)
  • 自定义中间件:您可以为菜单项添加自己的中间件
  • 表前缀:默认情况下,此包将创建两个新表,名为"menus"和"menu_items",但您仍然可以添加自己的表前缀,以避免与现有表冲突
  • 表名:如果您想使用特定的表名,则必须修改它以及迁移文件
  • 自定义路由:如果想要编辑路由路径,则可以编辑该字段
  • 角色访问:如果想要在菜单项上启用角色(权限)
  1. 运行迁移
php artisan migrate

完成

菜单构建器使用示例 - 显示构建器

在你的视图blade文件中

@extends('app')

@section('contents')
    {!! Menu::render() !!}
@endsection

//YOU MUST HAVE JQUERY LOADED BEFORE menu scripts
@push('scripts')
    {!! Menu::scripts() !!}
@endpush

使用模型

调用模型类

use Mykholy\Menu\Models\Menus;
use Mykholy\Menu\Models\MenuItems;

菜单使用示例(a)

一个基本的二级菜单可以在你的blade模板中显示

使用模型类
/* get menu by id*/
$menu = Menus::find(1);
/* or by name */
$menu = Menus::where('name','Test Menu')->first();

/* or get menu by name and the items with EAGER LOADING (RECOMENDED for better performance and less query call)*/
$menu = Menus::where('name','Test Menu')->with('items')->first();
/*or by id */
$menu = Menus::where('id', 1)->with('items')->first();

//you can access by model result
$public_menu = $menu->items;

//or you can convert it to array
$public_menu = $menu->items->toArray();
或使用助手
// Using Helper 
$public_menu = Menu::getByName('Public'); //return array

菜单使用示例(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 -->

助手

根据菜单ID获取菜单项

use Mykholy\Menu\Facades\Menu;
...
/*
Parameter: Menu ID
Return: Array
*/
$menuList = Menu::get(1);

根据菜单名称获取菜单项

在这个例子中,你必须有一个名为Admin的菜单

use Mykholy\Menu\Facades\Menu;
...
/*
Parameter: Menu ID
Return: Array
*/
$menuList = Menu::getByName('Admin');

自定义

您可以在resources/views/vendor/wmenu/menu-html.blade.php中编辑菜单界面

致谢

  • wmenu laravel包,菜单类似于WordPress

兼容性

  • 在laravel 5.2,5.3,5.4,5.5,5.6,5.7,5.8,6.x,7.x上进行了测试

已知问题

  • 不适用于RTL网站 #21(欢迎pull requests)