Eri*_*ann 0 php layout templates laravel blade
问题是我的 about.blade.php 文件显示在布局中,但我的 navbar.blade.php 没有。
我能猜到的最好的(我是 Laravel 的新手)是我的控制器返回 about.blade.php,它扩展了 layout.blade.php,但由于某种原因,layout.blade 甚至不知道 navbar.blade.php虽然 navbar.blade.php 扩展了 layout.blade.php。
layout.blade.php
<!DOCTYPE html>
<html>
<head>
</head>
<body>
@yield('navbar')
<div class="container">
@yield('content')
</div>
</body>
</html>
Run Code Online (Sandbox Code Playgroud)
导航栏.blade.php
@extends('layout')
@section('navbar')
<header>
<nav class="nav navbar-default navbar-fixed-top">
<div class="container-fluid">
<div class="navbar-header">
<button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar-collapse-1" aria-expanded="false">
<span class="sr-only">Toggle Navigation</span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button>
<a class="navbar-brand" href="/?page=main">SWMHS</a>
</div>
<div class="collapse navbar-collapse" id="navbar-collapse-1">
<ul class="nav navbar-nav">
<li><a href="/">Main</a></li>
<li><a href="/about">About</a></li>
</ul>
</div>
</div>
</nav>
</header>
@endsection
Run Code Online (Sandbox Code Playgroud)
关于.blade.php
@extends('layout')
@section('content')
<h1 class="text-center">This is the About Page</h1>
@endsection
Run Code Online (Sandbox Code Playgroud)
该yield指令并不像您认为的那样工作。如果该部分已添加到刀片模板,它只会显示内容。
您需要添加一个navbar部分并将其复制并粘贴到您希望它显示的每个视图中。另一种方法是创建一个部分和@include()导航栏模板。
假设您的navbar模板不会更改,则应该这样做。
layout.blade.php
<!DOCTYPE html>
<html>
<head>
</head>
<body>
@include('partials.navbar')
<div class="container">
@yield('content')
</div>
</body>
</html>
Run Code Online (Sandbox Code Playgroud)
部分/navbar.blade.php
<header>
<nav class="nav navbar-default navbar-fixed-top">
<div class="container-fluid">
<div class="navbar-header">
<button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar-collapse-1" aria-expanded="false">
<span class="sr-only">Toggle Navigation</span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button>
<a class="navbar-brand" href="/?page=main">SWMHS</a>
</div>
<div class="collapse navbar-collapse" id="navbar-collapse-1">
<ul class="nav navbar-nav">
<li><a href="/">Main</a></li>
<li><a href="/about">About</a></li>
</ul>
</div>
</div>
</nav>
</header>
Run Code Online (Sandbox Code Playgroud)
关于.blade.php
@extends('layout')
@section('content')
<h1 class="text-center">This is the About Page</h1>
@endsection
Run Code Online (Sandbox Code Playgroud)