Blade模板簡介
問: 什么是Blade模板?
答: Blade模板是Laravel提供一個既簡單又強大的模板引擎;
和其他流行的PHP模板引擎不一樣,他并不限制你在視圖里使用原生PHP代碼;
所有Blade視圖頁面都將被編譯成原生的PHP代碼并緩存起來,除非你的模板文件被修改,否則不會重新編譯。
而這些都意味著Blade不會給我們增加任何負擔。
在其他框架中,分頁可能是件非常痛苦的事,Laravel 讓這件事變得簡單、易于上手。Laravel 的分頁器與查詢構建器和 Eloquent ORM 集成在一起,并開箱提供方便的、易于使用的、基于數(shù)據(jù)庫結果集的分頁。分頁器生成的 HTML 兼容 Bootstrap CSS 框架。
基本使用
基于查詢構建器進行分頁 有多種方式實現(xiàn)分頁功能,最簡單的方式就是使用查詢構建器或 Eloquent 查詢提供的 paginate 方法。該方法基于當前用戶查看頁自動設置合適的偏移(offset)和限制(limit),直白點說就是頁碼和每頁顯示數(shù)量。默認情況下,當前頁通過 HTTP 請求查詢字符串參數(shù) page 的值判斷。當然,該值由 Laravel 自動檢測,然后自動插入分頁器生成的鏈接中。
讓我們先來看看如何在查詢中調(diào)用 paginate 方法。在本例中,傳遞給 paginate 的唯一參數(shù)就是你每頁想要顯示的數(shù)目,這里我們指定每頁顯示 15 個:
?php
namespace App\Http\Controllers;
use Illuminate\Support\Facades\DB;
use App\Http\Controllers\Controller;
class UserController extends Controller
{
/**
* 顯示應用中的所有用戶
*
* @return Response
*/
public function index()
{
$users = DB::table('users')->paginate(15);
return view('user.index', ['users' => $users]);
}
}
注:目前,使用 groupBy 的分頁操作不能被 Laravel 有效執(zhí)行,如果你需要在分頁結果中使用 groupBy,推薦你手動查詢數(shù)據(jù)庫然后創(chuàng)建分頁器。
簡單分頁
如果你只需要在分頁視圖中簡單的顯示“下一頁”和“上一頁”鏈接,可以使用 simplePaginate 方法來執(zhí)行一個更加高效的查詢。在渲染包含大數(shù)據(jù)集的視圖且不需要顯示每個頁碼時這一功能非常有用:
$users = DB::table('users')->simplePaginate(15);
顯示分頁結果
當調(diào)用 paginate 方法時,你將獲取Illuminate\Pagination\LengthAwarePaginator 實例,而調(diào)用方法simplePaginate 時,將會獲取 Illuminate\Pagination\Paginator 實例。這些對象提供相關方法描述這些結果集,除了這些輔助函數(shù)外,分頁器實例本身就是迭代器,可以像數(shù)組一樣對其進行循環(huán)調(diào)用。所以,獲取到結果后,可以按如下方式使用 Blade 顯示這些結果并渲染頁面鏈接:
div class="container">
@foreach ($users as $user)
{{ $user->name }}
@endforeach
/div>
{{ $users->links() }}
links 方法將會將結果集中的其它頁面鏈接渲染出來。每個鏈接已經(jīng)包含了 page 查詢字符串變量。記住,render 方法生成的 HTML 兼容 Bootstrap CSS 框架。
帶條件的分頁
public function index()
{
$type = $this->request->get('type',1);
$users = DB::table('users')->where(function ($query) use ($type) {
if($type) {
$query->where('type', $type);
}
})->paginate(15);
return view('user.index', ['users' => $users]);
}
]
div class="container">
@foreach ($users as $user)
{{ $user->name }}
@endforeach
/div>
{!! $list->appends(['type'=>$type])->links() !!}
知識點補充:
Laravel框架中Blade模板的用法
1. 繼承、片段、占位、組件、插槽
1.1 繼承
1、定義父模板 Laravel/resources/views/base.blade.php
2、子模板繼承 @extends('base')
1.2 片段
1、父模板定義片段
@section('part')
// 中間內(nèi)容即使是一個片段
@show
2、子模板填充片段
@section('part')
// 片段填充內(nèi)容(后臺的表單、列表等)
@endsection
1.3 占位
1、父模板占位
@yield('title')
2、子模板填充占位
第一種填充(文本):
@section('title' , '填充的文本占位')
第二種填充(文本 or html)
@section('title')
// 填充的占位
@endsection
1.4 組件、插槽
1、定義組件
// 路徑:Laravel/resources/views/component.blade.php
div class='component'>
!-- $title,$content 變量實際上就是預定義的插槽 -->
div class='title'>{{ $title }}/div>
div class='content'>{{ $content }}/div>
/div>
2、使用組件
// 路徑:Laravel/resources/views/test.blade.php
@component('component')
@slot('title')
組件標題
@endsolt
@slot('content')
組件內(nèi)容
@endslot
@endcomponent
2.數(shù)據(jù)顯示
2.1 轉義輸出
{{ $name }}
2.2 未轉義輸出
{!! $name !!}
2.3 打印內(nèi)容并帶一個默認值
{{ $var or 'default' }}
2.4 原格式輸出
// 第一種(適合量不多):
@{{ name }}
// 第二種(適合量多):
@verbatim
{{ name }}
{{ sex }}
{{ age }}
@endverbatim
3. 流程控制
3.1 for
@for ($i = 0; $i 10; ++$i)
{{ $i }} br />
@endfor
3.2 foreach
@foreach ($data as $k => $v)
{{ $k }} br />
@endforeach
3.3 forelse
@foreach ($data as $k => $v)
// $data有值
{{ $k }} br />
@empty
// $data沒有值
@endforeach
3.4 if
@if(condition) - if開始
@else - else不帶條件
@elseif(condition) - else帶條件
@endif - 結束if
3.5 while
@while(condition) - while循環(huán)開始
@endwhile - while循環(huán)結束
3.6 unless
@unless(condition) - unless開始
@endunless - unless結束
4. 使用原生 PHP
@php
// 里面寫php代碼
echo "使用原生 PHP";
@endphp
5. 包含子視圖
被包含的子視圖可以引用父視圖定義的所有變量。
你可以傳遞額外的數(shù)據(jù)到子視圖
定義父視圖 parent.blade.php,并包含子視圖 child.blade.php,且傳入額外數(shù)據(jù)
!-- 包含子視圖 -->
@include("child" , [
"other" => "額外數(shù)據(jù)"
])
總結
到此這篇關于laravel中blade模板帶條件分頁的文章就介紹到這了,更多相關laravel blade模板內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- 解決Laravel blade模板轉義html標簽的問題
- Laravel框架之blade模板新手入門教程及小技巧
- Laravel中的Blade模板引擎示例詳解
- 如何通過View::first使用Laravel Blade的動態(tài)模板詳解
- Laravel框架中Blade模板的用法示例
- Laravel模板引擎Blade中section的一些標簽的區(qū)別介紹