ホームページ バックエンド開発 PHPチュートリアル Laravel5 生徒成績管理システム-02-ブレードテンプレート

Laravel5 生徒成績管理システム-02-ブレードテンプレート

Jun 23, 2016 pm 01:08 PM

Blade は、Laravel が提供するシンプルで強力なテンプレート エンジンです。他のよく知られた PHP テンプレート エンジンと比較して、Blade ではビューでの PHP コードの使用が制限されません。すべての Blade ビューは、変更されるまでコンパイルされ、プレーンな PHP コードにキャッシュされます。これは、Blade がアプリケーションにほとんど負担をかけないことを意味します。ブレード ビュー ファイルは拡張子として .blade.php を使用し、通常は resource/views フォルダーに保存されます。

# ページ レイアウトを定義する

Blade テンプレートを使用する 2 つの主な利点は、テンプレートの継承とブロックです。簡単な例から始めましょう。まず、「メイン」ページのレイアウトを確認する必要があります。ほとんどの Web アプリケーションは、さまざまなページで同じレイアウトを維持します。このレイアウトは、次の単一の Blade ビューで簡単に定義できます。 .

      <!-- 文件保存于 resources/views/master.blade.php --><!DOCTYPE html><html lang="en"><head>    <meta charset="utf-8">    <meta http-equiv="X-UA-Compatible" content="IE=edge">    <meta name="viewport" content="width=device-width, initial-scale=1">    <title> @yield('title') </title>    <link rel="stylesheet" href="http://cdn.bootcss.com/bootstrap/3.3.4/css/bootstrap.min.css"></head><body><nav class="navbar navbar-default">    <div class="container">        <div class="navbar-header">            <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1">                <span class="sr-only">Toggle Navigation</span>                <span class="icon-bar"></span>                <span class="icon-bar"></span>                <span class="icon-bar"></span>            </button>            @if(Auth::guest()) <a class="navbar-brand" href="/">学生成绩管理</a>            @else                @if (Auth::user()->is_admin) <a class="navbar-brand" href="/admin">学生成绩管理</a>                @else <a class="navbar-brand" href="/">学生成绩管理</a>                @endif            @endif </div>        <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">            <ul class="nav navbar-nav">                <li><a href="http://www.golaravel.com" target="__blank">Power by laravel5</a></li>            </ul>            <ul class="nav navbar-nav navbar-right">                @if (Auth::guest())                @else <li class="dropdown">                        <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false">{{ Auth::user()->name }} <span class="caret"></span></a>                        <ul class="dropdown-menu" role="menu">                            <li><a href="{{ url('/logout') }}">退出</a></li>                        </ul>                    </li>                @endif </ul>        </div>    </div></nav><!-- <div>{{-- <!-- @include('flash') --}}  </div> -->@yield('content') <!-- script --><script src="http://cdn.bootcss.com/jquery/1.11.2/jquery.min.js"></script><script src="http://cdn.bootcss.com/bootstrap/3.3.4/js/bootstrap.min.js"></script></body></html>
ログイン後にコピー


ご覧のとおり、このファイルには従来の HTML 構文が含まれています。ただし、@section および @yield コマンドに注意してください。名前が示すように、@section コマンドはコンテンツ セクションを定義し、@yield コマンドは「指定されたセクションのコンテンツを表示する」ために使用されます。

@yield() [単にエリアとして理解できます] と @extends() は、通常、レイアウトと呼ばれるものを実現するために組み合わせて使用​​されます。レイアウトとは、Web 開発のプロセスで、ヘッダー、フッターなどのいくつかの共通部分をビュー ファイルに直接配置し、それを使用するときに (@extends を使用して) 直接継承を使用することを意味します。 / views/ フォルダーの下に master.blade.php を作成します。

このアプリケーションのレイアウトを定義したので、このレイアウトを継承するサブページを定義しましょう。


#ページ レイアウトの継承


サブページを定義する場合、Blade の @extends コマンドを使用して、サブページがどのレイアウトを「継承」するかを指定できます。ビュー @extends Blade のレイアウト後、@section コマンドを使用してコンテンツをレイアウト ブロックに挿入できます。上の例に見られるように、これらのブロックのコンテンツは @yield を使用してレイアウトに表示されることを覚えておいてください:

‍ ウェルカム ホーム ページはメイン ページを継承します‍

      <!-- 文件保存于 resources/views/welcome.blade.php -->@extends('master')    {{-- 继承master模版,注意:此处米有结束符分号 --}}@section('title')   {{-- 对应@yield('title') --}}  {{-- 也可以这样写:@section('title', '页面标题') --}}    学生成绩管理系统-测试-@stop@section('content')    {{-- 对应@yield('content') --}}    <div class="container">        <div class="jumbotron">            <h2><div class="quote">{{ Inspiring::quote() }}</div></h2>            <p>同学们登录后先修改相关资料</p>            <p>查询分数,有疑问咨询管理员</p>            <p><a class="btn btn-primary btn-lg" href="/login" role="button">点击登录</a></p>        </div>    </div>@stop
ログイン後にコピー

@section には 2 つの書き方があります:


1 つ目の方法 コンテンツが比較的短い場合は、@stop 終了記号を付けずに直接記述することができます

      @section('title', '页面标题')
ログイン後にコピー

2 つ目の方法は、表示するコンテンツが多い場合、個別に記述することができます。つまり、次のようになります。

      @section('content')    // 这部分替换app里的代码,有开始就会有结束,所以一个section 对应一个stop <h1>生如夏花之绚烂</h1> <p>死如秋叶之静美</p>@stop
ログイン後にコピー


ブラウザ表示:

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

11ベストPHP URLショートナースクリプト(無料およびプレミアム) 11ベストPHP URLショートナースクリプト(無料およびプレミアム) Mar 03, 2025 am 10:49 AM

11ベストPHP URLショートナースクリプト(無料およびプレミアム)

Instagram APIの紹介 Instagram APIの紹介 Mar 02, 2025 am 09:32 AM

Instagram APIの紹介

Laravelでフラッシュセッションデータを使用します Laravelでフラッシュセッションデータを使用します Mar 12, 2025 pm 05:08 PM

Laravelでフラッシュセッションデータを使用します

LaravelのバックエンドでReactアプリを構築する:パート2、React LaravelのバックエンドでReactアプリを構築する:パート2、React Mar 04, 2025 am 09:33 AM

LaravelのバックエンドでReactアプリを構築する:パート2、React

Laravelテストでの簡略化されたHTTP応答のモッキング Laravelテストでの簡略化されたHTTP応答のモッキング Mar 12, 2025 pm 05:09 PM

Laravelテストでの簡略化されたHTTP応答のモッキング

PHPのカール:REST APIでPHPカール拡張機能を使用する方法 PHPのカール:REST APIでPHPカール拡張機能を使用する方法 Mar 14, 2025 am 11:42 AM

PHPのカール:REST APIでPHPカール拡張機能を使用する方法

Codecanyonで12の最高のPHPチャットスクリプト Codecanyonで12の最高のPHPチャットスクリプト Mar 13, 2025 pm 12:08 PM

Codecanyonで12の最高のPHPチャットスクリプト

Laravelの通知 Laravelの通知 Mar 04, 2025 am 09:22 AM

Laravelの通知

See all articles