Yii2之面包屑组件重写以兼容BootStrap4
18-01-08 20:53
字数 1250
阅读 3803
已编辑
因为把Yii2的bootstrap组件升级到了4.0beta,所以以前的生成面包屑的组件不能用了。
<?php
use yii\widgets\Breadcrumbs;
?>
<?= Breadcrumbs::widget([
'links' => isset($this->params['breadcrumbs']) ? $this->params['breadcrumbs'] : [],
]) ?>
还按以前的方式生成面包屑的话生成的html代码是这样式的。
<ul class="breadcrumb"><li><a href="/index.php">首页</a></li>
<li class="active">登录</li>
</ul>
这样的代码在bootstrap4中显示的效果是这样的。
这样显然是不行的,样式全错了。在bootstrap4中的面包屑应该这样写。
<nav aria-label="breadcrumb">
<ol class="breadcrumb">
<li class="breadcrumb-item"><a href="#">Home</a></li>
<li class="breadcrumb-item active" aria-current="page">Library</li>
</ol>
</nav
所以我们需要修改一下才行。
于是新建一个Breadcrumbs widget 继承至\yii\widgets\Breadcrumbs
,通过阅读源代码得知,需要重写一下属性
$tag
, $itemTemplate
, $activeItemTemplate
。
/**
* rerite Breadcrumbs widget to fix bt4
* @user: luzhuang
* @date: 2018/1/8
* @time: 下午8:16
*/
namespace app\widgets;
use yii\helpers\Html;
class Breadcrumbs extends \yii\widgets\Breadcrumbs
{
public $tag = "ol";
public $itemTemplate = "<li class='breadcrumb-item'>{link}</li>\n";
public $activeItemTemplate = "<li class=\"breadcrumb-item active\" aria-current=\"page\">{link}</li>\n";
}
重写完这三个属性之后生成的代码是这样的。
<ol class="breadcrumb"><li class="breadcrumb-item"><a href="/index.php">首页</a></li>
<li class="breadcrumb-item active" aria-current="page">登录</li>
</ol>
显示出来的效果是这样的。
虽然好像差不多了,但是和bootstrap的官网文档对比好像还是差点。
少点什么呢?
官方文档中的<ol>xxx</ol>
外边有一个<nav aria-label="breadcrumb">
包裹着,于是继续阅读源码。
看到下面这行代码。
/**
* Renders the widget.
*/
public function run()
{
if (empty($this->links)) {
return;
}
$links = [];
if ($this->homeLink === null) {
$links[] = $this->renderItem([
'label' => Yii::t('yii', 'Home'),
'url' => Yii::$app->homeUrl,
], $this->itemTemplate);
} elseif ($this->homeLink !== false) {
$links[] = $this->renderItem($this->homeLink, $this->itemTemplate);
}
foreach ($this->links as $link) {
if (!is_array($link)) {
$link = ['label' => $link];
}
$links[] = $this->renderItem($link, isset($link['url']) ? $this->itemTemplate : $this->activeItemTemplate);
}
echo Html::tag($this->tag, implode('', $links), $this->options);
}
原来是这个run
方法输出了html代码,所以获取到这个返回值,照葫芦画瓢也用Html::tag
方法在外边包一层nav
就行。
但是坑爹的是这个run
方法并没有返回值,而是直接echo
出了结果。
这改如何是好,机智如我怎么会被这个难道,虽然你不return
,但是我还是可以通过其他的方式获取到结果。
/**
* rerite Breadcrumbs widget to fix bt4
* @user: luzhuang
* @date: 2018/1/8
* @time: 下午8:16
*/
namespace app\widgets;
use yii\helpers\Html;
class Breadcrumbs extends \yii\widgets\Breadcrumbs
{
public $wrapper = "nav";
public $tag = "ol";
public $itemTemplate = "<li class='breadcrumb-item'>{link}</li>\n";
public $activeItemTemplate = "<li class=\"breadcrumb-item active\" aria-current=\"page\">{link}</li>\n";
public function run()
{
ob_start();
parent::run();
$result = ob_get_clean();
return Html::tag($this->wrapper, $result, ["aria-label" => "breadcrumb"]);
}
}
最终生成的代码如下。
<nav aria-label="breadcrumb"><ol class="breadcrumb"><li class="breadcrumb-item"><a href="/index.php">首页</a></li>
<li class="breadcrumb-item active" aria-current="page">登录</li>
</ol></nav>
ok~ 这下完美了。ob_
方法在一些情况下还是很好用滴。
0人点赞>
0 条评论
排序方式
时间
投票
快来抢占一楼吧
请登录后发表评论
相关推荐
文章归档
2024-11
1 篇
2024-06
1 篇
2024-05
2 篇
2024-04
2 篇
2024-03
2 篇
展开剩余 68 条
2024-01
1 篇
2023-10
1 篇
2023-09
1 篇
2023-08
1 篇
2023-06
1 篇
2023-04
1 篇
2022-12
2 篇
2022-06
1 篇
2022-04
4 篇
2022-03
3 篇
2022-01
6 篇
2021-12
2 篇
2021-11
2 篇
2021-10
2 篇
2021-09
1 篇
2021-08
2 篇
2021-07
4 篇
2021-06
1 篇
2021-05
3 篇
2021-04
3 篇
2021-01
2 篇
2020-11
1 篇
2020-10
3 篇
2020-09
2 篇
2020-08
1 篇
2020-07
5 篇
2020-06
5 篇
2020-05
1 篇
2020-04
1 篇
2020-03
2 篇
2020-02
3 篇
2020-01
1 篇
2019-11
5 篇
2019-10
10 篇
2019-09
12 篇
2019-08
17 篇
2019-07
8 篇
2019-05
3 篇
2019-04
8 篇
2019-03
7 篇
2019-02
8 篇
2019-01
5 篇
2018-12
7 篇
2018-11
8 篇
2018-10
4 篇
2018-09
7 篇
2018-08
12 篇
2018-07
9 篇
2018-06
6 篇
2018-05
11 篇
2018-04
18 篇
2018-03
1 篇
2018-02
2 篇
2018-01
10 篇
2017-12
14 篇
2017-11
44 篇
2017-10
13 篇
2017-09
4 篇
2017-08
12 篇
2017-07
5 篇
2017-06
4 篇
2017-05
2 篇
2017-04
3 篇
2017-03
9 篇
2017-02
3 篇
2017-01
2 篇
2016-12
10 篇
2016-11
4 篇
最新文章
最受欢迎
11-07 19:00
06-26 11:51
05-17 17:08
05-17 10:59
04-11 17:05
13 评论
11 评论
10 评论