Laravel 5框架学习之Blade 简介

2025-05-29 0 47

在多个页面中我们可能包含相同的内容,像是文件头,链接的css或者js等。我们可以利用布局文件完成这个功能。

让我们新建一个布局文件,例如 views/layout.blade.php

?

1

2

3

4

5

6

7

8

9

10

11

12

13
<!doctype html>

<html lang="en">

<head>

<meta charset="UTF-8">

<title>Document</title>

<link rel="stylesheet" href="http://cdn.bootcss.com/bootstrap/3.3.4/css/bootstrap.min.css">

</head>

<body>

<div class="container">

@yield('content')

</div>

</body>

</html>

我们创建了不解的结构,引入了bootstrap,注意 @yield 是blade的布局占位符,未来我们的页面内容将填充到这里,修改 about.blade.php

?

1

2

3

4

5

6

7
@extends('layout')

@section('content')

<h1>About {{ $first }} {{ $last }}</h1>

@stop

上面的代码表示我们使用布局文件 layout.blade.php, 然后在 content 段中添加内容。

在 routes.php 中添加:

?

1

2
Route::get('about', 'PagesController@about');

Route::get('contact', 'PagesController@contact');

在 PagesController.php 中添加:

?

1

2

3
public function contact() {

return view('pages.contact');

}

新建视图 pages/contact.blade.php

?

1

2

3

4

5
@extends('layout')

@section('content')

<h1>Contact Me!</h1>

@stop

Check it out!

在布局文件中我们可以添加多个 @yield , 比如在 layout.blade.php 中添加 @yield('footer') :

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15
<!doctype html>

<html lang="en">

<head>

<meta charset="UTF-8">

<title>Document</title>

<link rel="stylesheet" href="http://cdn.bootcss.com/bootstrap/3.3.4/css/bootstrap.min.css">

</head>

<body>

<div class="container">

@yield('content')

</div>

@yield('footer')

</body>

</html>

比如 contact.blade.php 中有一段脚本,就可以放在这个段中。

?

1

2

3

4

5

6

7

8

9

10

11
@extends('layout')

@section('content')

<h1>Contact Me!</h1>

@stop

@section('footer')

<script>

alert('Contact from scritp')

</script>

@stop

访问contact会有对话框,而about仍然是普通显示

使用 @if 进行判断

?

1

2

3

4

5

6

7

8

9
@extends('layout')

@section('content')

@if ($first = 'Zhang')

<h1>Hello, Zhang</h1>

@else

<h1>Hello, nobody</h1>

@endif

@stop

也可以视同 @unless 等同于 if !, 还有 @foreach 等。

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19
public function about()

{

$people = [

'zhang san',

'li si',

'wang wu'

];

return view('pages.about', compact('people'));

}

@extends('layout')

@section('content')

<h1>Person:</h1>

<ul>

@foreach($people as $person)

<li>{{ $person }}</li>

@endforeach

</ul>

@stop

有一种情况,数据可能来自数据库,集合可能是空,像是这样:

复制代码 代码如下:


$people = [];

处理这种情况,请添加 @if 处理

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14
@extends('layout')

@section('content')

@if (count($people))

<h1>Person:</h1>

<ul>

@foreach($people as $person)

<li>{{ $person }}</li>

@endforeach

</ul>

@endif

<h2>Other info</h2>

@stop

That's better.

以上所述就是本文的全部内容了,希望能够对大家学习Laravel5有所帮助。

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 Laravel 5框架学习之Blade 简介 https://www.kuaiidc.com/102205.html

相关文章

发表评论
暂无评论