溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

laravel中Blade模板指的是什么

發(fā)布時(shí)間:2021-03-12 10:40:06 來源:億速云 閱讀:223 作者:小新 欄目:編程語言

小編給大家分享一下laravel中Blade模板指的是什么,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

Blade模板是是Laravel提供的模板引擎,它簡單強(qiáng)大,Blade允許在視圖中使用原生PHP代碼,Laravel使用的是編譯后的緩存文件,而不是視圖本身,所以Blade對于應(yīng)用程序來說是零開銷。

Blade模板是:

Blade 是 Laravel 提供的模板引擎,它簡單強(qiáng)大。不像其他的 PHP 模板引擎,Blade 允許在視圖中使用原生 PHP 代碼。

實(shí)際上,所有的 Blade 視圖最終都會被編譯成原生 PHP 代碼,緩存在 storage/framework/views 文件夾中。

Laravel 使用的是這些編譯后的緩存文件,而不是視圖本身,所以,Blade 對于應(yīng)用程序來說是零開銷的。當(dāng)你修改了視圖文件,那么它會重新編譯并緩存,以便使用。Blade 視圖以 blade.php 為后綴名,一般存放于 resources/views 文件夾中。

模板繼承:

1、定義布局文件

Blade 模板引擎的主要兩個(gè)優(yōu)點(diǎn)是 “模板繼承” 和 “區(qū)塊”。舉一個(gè)簡單的例子,一個(gè)項(xiàng)目里,幾乎所有的頁面都是一樣的布局,這時(shí)候就可以把這個(gè)布局提煉出來,作為母版頁,繼承了這個(gè)母版頁的的頁面都有一樣的布局效果,成為母版頁的子頁。母版頁還叫布局文件,布局文件就是一個(gè) Blade 視圖:

<!-- Stored in resources/views/layouts/app.blade.php -->
<html>
       <head>
             <title>App Name - @yield('title')</title>
       </head>
       <body>
         @section('sidebar')
               This is the master sidebar.
         @show
         <div class="container">
              @yield('content')
         </div>
       <body>
</html>

布局文件里除了基礎(chǔ)的 HTNL 標(biāo)簽,還使用了兩個(gè)指令:@section 和 @yield 。@section定義區(qū)塊,@yield 定義區(qū)塊里的內(nèi)容。

下面。來定義布局文件的子頁。

2、繼承布局文件

子頁中,使用 Blade 的 @extends 指令指定 “繼承” 的布局文件,使用 @section 指令為在布局文件中使用 @section 和 @yield 指令的地方注入內(nèi)容:

<!-- Stored in resources/views/child.blade.php -->
@extends('layouts.app')
@section('title','Page Title')
@section('sidebar')
       <p> This is appended to the master sideebar</p>
@endsection
@section('content')
         <p>This ismy body content. </p>
@endsection

可以看到,在布局文件中使用 @yield 指令的地方,在子頁中仍然使用 @section 注入內(nèi)容;在布局文件中使用 @section 指令定義的一個(gè)好處是:在子頁中使用 @section 注入時(shí),可以使用 @parent 指令附加(而非重寫)在布局文件中的內(nèi)容,而在布局文件中使用 @yield 指令定義的地方是做不到的。@parent 指令會在視圖渲染的時(shí)替換成布局文件里的內(nèi)容。

注意,與在文件布局里定義的 sidebar 不同的是,子頁里使用 @endsection 結(jié)束,而非 @show 。因?yàn)?@endsection 僅用來定義區(qū)塊,而 @show 是用來定義、立馬產(chǎn)出區(qū)塊的。

從路由中直接返回視圖文件,要用到全局輔助函數(shù) helper :

Route::get('blade', function(){
        return view('child');
})

3、組件&插槽

組件和插槽提供了類似布局和區(qū)塊的優(yōu)點(diǎn)。而組件和插槽的心智模型更符合直覺。設(shè)想一下,在我們的項(xiàng)目中有一個(gè)可重復(fù)的 “彈框” 組件:

<!-- Stored resource/views/alter.blade.php -->
<div class="alter alter-danger">
       {{ $slot }}
</div>

{{ $slot }} 表示插入組建的內(nèi)容。構(gòu)建此組件,是使用 Blade 的@component指令:

@component('alter')
        <strong>Whoops!</strong> Something went wrong!
@endcomponent

在這個(gè)場景里,{{ $slot }} 變量的內(nèi)容是:

<strong>Whoops! </strong> Something went wrong!

有時(shí)一個(gè)組件需要多個(gè)插槽。這時(shí),只需要稍改組件代碼,定義一個(gè) “標(biāo)題” 插槽,這個(gè)插槽稱命名插槽。命名插槽是通過簡單的 “打印” 匹配其名稱的變量來顯示內(nèi)容的:

<!-- Stored resources/views/alter.blade.php-->
<div class="alter alter-danger">
         <div class="alter-title">{{ $title }}</div>
            {{ $slot }}
</div>

為名名插槽注入內(nèi)容,使用 @slot 指令。所有不在 @slot 指令里的內(nèi)容都會傳遞給組件里的 $slot 變量。

@compontent ('alter')
         @slot('title')
            Forbidden
         @endslot
     You are not allowed to access this resource!
@edcompontent~

4、為組建傳遞額外數(shù)據(jù):

有時(shí)需要為組建件遞額外數(shù)據(jù)。為此,可以為 @conponent 指令傳遞第二個(gè)數(shù)組參數(shù)。指定要傳遞的額外。據(jù)所有過去的額外數(shù)據(jù)作為變量,在組件模板里都可以取的:

@component
     <compontent('alter', ['foo' => 'bar');
         .....
@endCompontent

5、顯示數(shù)據(jù)

向 Blade 視圖傳遞數(shù)據(jù),是通過將變量包裹在 [ ] 里實(shí)現(xiàn)的:

Route::get('greeting', function(){
         return view('welcome', [ 'name' => ''Samantha']);
})

下面就可以使用 name 變量顯示內(nèi)容了:

Hello! {{ $name }}

{{ }} 是 Blade 視圖的打印語句,當(dāng)然,打印語句里不限制只能打印變量內(nèi)容,也可以使用 PHP 函數(shù)。實(shí)際上,打印語句這里可以使用任何 PHP 代碼:

The current UNIX timestamp is {{ time() }}

6、顯示非轉(zhuǎn)移數(shù)據(jù)

默認(rèn),所有傳遞給 Blade {{ }} 語句的內(nèi)容都會使用 htmlspecialchar 函數(shù)處理、將內(nèi)容轉(zhuǎn)義,避免 XSS 攻擊。如果無需轉(zhuǎn)義輸出的內(nèi)容,可以使用下面語法:

Hello! {{!! $name !!}}.

不過千萬要小心,應(yīng)該優(yōu)先選擇使用轉(zhuǎn)義的 {{ }} 語法避免 XXS 攻擊。因?yàn)?,有時(shí)你很難避免用戶有意的、無意的數(shù)據(jù)輸入。

看完了這篇文章,相信你對“l(fā)aravel中Blade模板指的是什么”有了一定的了解,如果想了解更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI