当前位置:首页 > 编程技术 > 正文内容

Laravel扩展推荐:导航元素工具“Laravel Navigation”

yc8881年前 (2022-11-23)编程技术315

本篇文章给大家分享一个Laravel扩展:Laravel Navigation包,介绍一下怎么利用Laravel Navigation 轻松构建站点导航元素,希望对大家有所帮助!


更多教程欢迎点击:编程技术


Laravel Navigation 是 Spatie 的一个包,用于管理 Laravel 应用程序中的菜单、面包屑和其他导航元素.

Laravel

虽然 Spatie Laravel Menu 包是 Laravel 的 Html 菜单生成器,但可以将此包视为导航组件的「无渲染组件」:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

app(Navigation::class)

    ->add('Home', route('home'))

    ->add('Blog', route('blog.index'), function (Section $section) {

        $section

            ->add('All posts', route('blog.index'))

            ->add('Topics', route('blog.topics.index'));

    })

    ->addIf(Auth::user()->isAdmin(), function (Navigation $navigation) {

        $navigation->add('Admin', route('admin.index'));

    });

 

// 渲染到树结构

app(Navigation::class)->tree();

 

/*

 

[

    { "title": "Home", "url": "/", "active": false, "children": [] },

    {

        "title": "Blog",

        "url": "/blog",

        "active": false,

        "children": [

            { "title": "All posts", "url": "/blog", "active": false, "children": [] },

            { "title": "Topics", "url": "/blog/topics", "active": true, "children": [] }

        ],

    },

    { "title": "Admin", "url": "/admin", "active": false, "children": [] }

]

 

*/


使用这个包,你还可以使用以下方法从导航生成面包屑:

1

2

3

4

5

6

7

8

9

10

11

12

13

// 在你的控制器中添加额外的页面

app(Navigation::class)->activeSection()->add($topic->name, route('blog.topics.show', $topic));

 

// Render to breadcrumbs

app(Navigation::class)->breadcrumbs();

 

/*

[

    { "title": "Blog", "url": "/blog" },

    { "title": "Topics", "url": "/blog/topics" },

    { "title": "Laravel", "url": "/blog/topics/laravel" }

]

*/



你可以在 GitHub 上了解此软件包、获取完整的安装说明并查看 源代码。感谢 Sebastian De Deyne 和 Spatie 团队提供这个包,以及像这个一样的所有出色的开源 PHP 和 Laravel 包


本站发布的内容若侵犯到您的权益,请邮件联系站长删除,我们将及时处理!


从您进入本站开始,已表示您已同意接受本站【免责声明】中的一切条款!


本站大部分下载资源收集于网络,不保证其完整性以及安全性,请下载后自行研究。


本站资源仅供学习和交流使用,版权归原作者所有,请勿商业运营、违法使用和传播!请在下载后24小时之内自觉删除。


若作商业用途,请购买正版,由于未及时购买和付费发生的侵权行为,使用者自行承担,概与本站无关。


本文链接:https://www.10zhan.com/biancheng/10079.html

标签: Laravel
分享给朋友:

“Laravel扩展推荐:导航元素工具“Laravel Navigation”” 的相关文章

【说站】laravel实现自定义404页面并给页面传值

【说站】laravel实现自定义404页面并给页面传值

以 laravel5.8 为例,虽然有自带的404页面,但太简单,我们更希望能自定义404页面,将用户留在站点。实现的方式很简单,将自定义的视图文件命名为 404.blade.php,并放到 reso...

【说站】Thymeleaf报错Error resolving template “XXX”

【说站】Thymeleaf报错Error resolving template “XXX”

修改了一下开源项目的目录结构访问突然报错Error resolving template “XXX”可能原因有如下三种:第一种可能:原因:在使用springboot的过程中,如果使用thymeleaf...

【说站】用一句话就可以去除宝塔面板操作上的二次验证

【说站】用一句话就可以去除宝塔面板操作上的二次验证

用过宝塔的朋友应该都会发现,现在宝塔面板有些鸡肋的功能,删除文件、删除数据库、删除站点等操作都需要做计算题!不仅加了几秒的延时等待,还无法跳过!这时候就会有朋友在想,如何去除宝塔面板的二次验证,此篇文...

【说站】Centos8.0如何配置静态IP详解及永久关闭防火墙

【说站】Centos8.0如何配置静态IP详解及永久关闭防火墙

这篇文章主要介绍了详解Centos8 配置静态IP的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来学习一下!1. 查看自己的网关地址点击虚...

【说站】利用Webhook实现Java项目自动化部署

【说站】利用Webhook实现Java项目自动化部署

用webhook就能实现Java项目自动部署,其实原理很简单。费话不多说,直接往下看教程。1. 创建gitee仓库并初始化2. 在linux安装git3. 在宝塔的软件的商店里下载Webhook4....

【说站】C#在PDF中添加墨迹注释Ink Annotation的步骤详解

【说站】C#在PDF中添加墨迹注释Ink Annotation的步骤详解

PDF中的墨迹注释(Ink Annotation),表现为徒手涂鸦式的形状;该类型的注释,可任意指定形状顶点的位置及个数,通过指定的顶点,程序将连接各点绘制成平滑的曲线。下面,通过C#程序代码介绍如何...