在mvc框架中,字母“v”代表视图(views)。它分离了应用程序逻辑并展现逻辑。视图文件存储在 resources/views目录。一般来说,视图是包含了应用程序的html。
第1步 - 复制下面的代码,并将其保存在 resources/views/test.php
<html>
<body>
<h1>hello, world</h1>
</body>
</html>
app/http/routes.php
route::get('/test', function(){
return view('test');
});
http://localhost:8000/test
当构建应用程序时,可能需要将数据传递到视图。传递一个数组到视图助手函数。传递一个数组后,我们可以使用它的键在html文件中来获得键对应的值。
第1步 - 复制下面的代码,并将其保存在 resources/views/test.php
<html>
<body>
<h1><?php echo $name; ?></h1>
</body>
</html>
app/http/routes.php
route::get('/test', function(){
return view('test',[‘name’=>’h3’]);
});
http://localhost:8000/test
我们已经看到如何能够将数据传递给视图,但有时,有必要将数据传递到所有的视图。laravel使得这更简单。有一个叫作 “share()” 方法,该方法可以用于这一目的。share() 方法带有两个参数,key和value。通常 share() 方法可以从服务提供者的启动方法被调用。我们可以使用任何服务提供者,appserviceprovider或我们自己的服务提供者。
app/http/routes.php
route::get('/test', function(){
return view('test');
});
route::get('/test2', function(){
return view('test2');
});
第2步-创建两个视图文件-test.php和test2.php的代码相同。以下是两个文件,这将共享数据。将以下代码复制到这两个文件中。resources/views/test.php & resources/views/test2.php
<html>
<body>
<h1><?php echo $name; ?></h1>
</body>
</html>
第3步- 更改启动方法的代码在文件 - app/providers/appserviceprovider.php 如下所示.
(在这里,我们使用了共享方法,而且我们通过与所有的视图共享数据。) app/providers/appserviceprovider.php
<?php
namespace app\providers;
use illuminate\support\serviceprovider;
class appserviceprovider extends serviceprovider {
/**
* bootstrap any application services.
*
* @return void
*/
public function boot(){
view()->share('name', 'h3');
}
/**
* register any application services.
*
* @return void
*/
public function register(){
//
}
}
http://localhost:8000/test
http://localhost:8000/test2
blade是一个简单,为laravel提供的强大模板引擎。blade是laravel轻量级模板语言,它的语法非常简单易学。blade模板包含扩展— blade.php 并存储在目录 resources/views.
blade也支持所有php的主要构造器,创造循环和条件 — @for, @foreach, @while, @if 和 @elseif, 使您以避免开在模板到处使用<?php标记。blade 模板的主要优点是,我们可以设置主模板,这个主模板可以被另一个页面进行扩展。
第1步 - 创建一个主模板,并将其保存在 - resources/views/layouts/master.blade.php.
<html>
<head>
<title>@yield('title')</title>
</head>
<body>
@section('sidebar')
this is the master sidebar.
@show
<div class = "container">
@yield('content')
</div>
</body>
</html>
@yield('title') 用于显示的标题的值
@section('sidebar')用于定义命名侧边栏部分
@show 用于显示一个部分内容
@yield('content') 用于显示 content 的内容
第3步 - 现在,创建另一个页面并扩展主模板,并将其保存在 - resources/views/page.blade.php
@extends('layouts.master')
@section('title', 'page title')
@section('sidebar')
@parent
<p>this is appended to the master sidebar.</p>
@endsection
@section('content')
<h2>{{$name}}</h2>
<p>this is my body content.</p>
@endsection
@extends('layouts.master') 用于扩展主布局。“layouts.master” — 在这里,layouts 是目录的名称,在这里我们已经存储在主模板 和 主模板 “master.blade.php”,这里“.master”是指其名字,但这里使用名称而不带扩展 blade.php
@section('title', 'page title') − 设置的标题部分的值
@section('sidebar') − 定义主布局的子页面侧边栏部分。
@parent − 在主布局定义中显示侧边栏部分的内容。
<p> − 这是追加到主侧边栏。</p> 增添一段内容到侧边栏部分
@endsection − 结束侧边栏部分。
@section('content') − 定义内容部分。
@section('content') − 增添段的内容到content 部分。
@endsection − 结束该内容部分。
第5步 - 现在,建立路由查看此模板。添加下面一行到文件 - app/http/routes.php
route::get('blade', function () {
return view('page',array('name' => 'h3'));
});
http://localhost:8000/blade



