xety / breadcrumbs
一个简单的具有流畅模式的面包屑生成器。
1.1.0
2023-02-01 14:03 UTC
Requires
- php: >=7.0
- xety/configurator: ~1.0
Requires (Dev)
- phpunit/phpunit: ~6.0
- squizlabs/php_codesniffer: ~3.0
- symfony/css-selector: ~3.3
- symfony/dom-crawler: ~3.3
- xety/phpdoc-md: dev-master
This package is auto-updated.
Last update: 2024-08-29 17:50:54 UTC
README
一个使用Fluent模式的面包屑生成器。这个库受到creitive/breadcrumbs的启发,但已被完全重写,以实现完全可定制。
需求
安装
composer require xety/breadcrumbs
用法
实例
要使用Breadcrumbs类,只需实例化它
use Xety\Breadcrumbs\Breadcrumbs; $breadcrumbs = new Breadcrumbs; // Or with breadcrumbs and options: $breadcrumbs = new Breadcrumbs( [ [ 'name' => 'Home', 'href' => '/home' ], [ 'name' => 'Blog', 'href' => '/blog' ] ], [ 'position' => true ] );
输出
要渲染面包屑,可以调用函数render()
或直接"echo"它
echo $breadcrumbs->render(); // Or, since this class implement the magic method `__toString()`, // you can directly echo the instance : echo $breadcrumbs;
输出示例
默认情况下,此类配置为使用Bootstrap 4样式渲染。因此,根据上述配置,输出将看起来像这样
<nav class="breadcrumb"> <a data-position="1" class="breadcrumb-item" href="/home">Home</a> <span data-position="2" class="breadcrumb-item active" href="/blog">Blog</span> </nav>
功能齐全的示例
$breadcrumbs = new Breadcrumbs( [ [ 'name' => 'Home', 'href' => '/home' ], [ 'name' => 'Blog', 'href' => 'blog' // Note there is no `slash` here. ], [ 'name' => 'Test', 'href' => 'http://xeta.io/blog/test' ], [ 'name' => 'Article', 'href' => '/article' ] ], [ 'position' => true, 'divider' => '#', 'dividerElement' => 'li', 'dividerElementClasses'=> [ 'custom', 'divider' ], 'listElement' => 'ul', 'listElementClasses' => [ 'custom', 'container' ], 'listItemElement' => 'li', 'listItemElementClasses' => [ 'custom', 'item' ], 'listActiveElement' => 'li', 'listActiveElementClasses' => [ 'custom', 'active' ] ] );
输出
<ul class="custom container"> <li data-position="1" class="custom item" href="/home">Home</li> <li class="custom divider">#</li> <li data-position="2" class="custom item" href="/blog">Blog</li> <!-- The slash has been automaticaly set by the class --> <li class="custom divider">#</li> <li data-position="3" class="custom item" href="http://xeta.io/blog/test">Test</li> <li class="custom divider">#</li> <li data-position="4" class="custom active">Article</li> </ul>
选项
这是所有可用选项和默认选项的列表
[ // Whether to enable or not the `data-position` attribute. 'position' => false, // The divider symbol between the crumbs or `null` to disable it. 'divider' => null, // The DOM-Element used to generate the divider element. 'dividerElement' => 'span', // Classes applied to the item `dividerElement` element. 'dividerElementClasses'=> [ 'divider' ], // The DOM-Element used to generate the container element. 'listElement' => 'nav', // Classes applied to the main `listElement` container element. 'listElementClasses' => [ 'breadcrumb' ], // The DOM-Element used to generate the list item. 'listItemElement' => 'a', // Classes applied to the list item `listItemElement` element. 'listItemElementClasses' => [ 'breadcrumb-item' ], // The DOM-Element used to generate the active list item. 'listActiveElement' => 'span', // Classes applied to the active item `listActiveElement` element. 'listActiveElementClasses' => [ 'breadcrumb-item', 'active' ] ]
文档
您可以在这里找到所有可用方法及其文档。
贡献
如果您想贡献,请遵循此指南。