- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章详解laravel中blade模板带条件分页由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
Blade模板简介 。
问: 什么是Blade模板?
答: Blade模板是Laravel提供一个既简单又强大的模板引擎; 和其他流行的PHP模板引擎不一样,他并不限制你在视图里使用原生PHP代码; 所有Blade视图页面都将被编译成原生的PHP代码并缓存起来,除非你的模板文件被修改,否则不会重新编译。 而这些都意味着Blade不会给我们增加任何负担.
在其他框架中,分页可能是件非常痛苦的事,Laravel 让这件事变得简单、易于上手。Laravel 的分页器与查询构建器和 Eloquent ORM 集成在一起,并开箱提供方便的、易于使用的、基于数据库结果集的分页。分页器生成的 HTML 兼容 Bootstrap CSS 框架.
基本使用 。
基于查询构建器进行分页 有多种方式实现分页功能,最简单的方式就是使用查询构建器或 Eloquent 查询提供的 paginate 方法。该方法基于当前用户查看页自动设置合适的偏移(offset)和限制(limit),直白点说就是页码和每页显示数量。默认情况下,当前页通过 HTTP 请求查询字符串参数 page 的值判断。当然,该值由 Laravel 自动检测,然后自动插入分页器生成的链接中.
让我们先来看看如何在查询中调用 paginate 方法。在本例中,传递给 paginate 的唯一参数就是你每页想要显示的数目,这里我们指定每页显示 15 个:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
<?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 有效执行,如果你需要在分页结果中使用 groupBy,推荐你手动查询数据库然后创建分页器.
简单分页 。
如果你只需要在分页视图中简单的显示“下一页”和“上一页”链接,可以使用 simplePaginate 方法来执行一个更加高效的查询。在渲染包含大数据集的视图且不需要显示每个页码时这一功能非常有用:
$users = DB::table('users')->simplePaginate(15),
显示分页结果 。
当调用 paginate 方法时,你将获取Illuminate\Pagination\LengthAwarePaginator 实例,而调用方法simplePaginate 时,将会获取 Illuminate\Pagination\Paginator 实例。这些对象提供相关方法描述这些结果集,除了这些辅助函数外,分页器实例本身就是迭代器,可以像数组一样对其进行循环调用。所以,获取到结果后,可以按如下方式使用 Blade 显示这些结果并渲染页面链接:
1
2
3
4
5
6
7
|
<div
class
=
"container"
>
@
foreach
(
$users
as
$user
)
{{
$user
->name }}
@
endforeach
</div>
{{
$users
->links() }}
|
links 方法将会将结果集中的其它页面链接渲染出来。每个链接已经包含了 page 查询字符串变量。记住,render 方法生成的 HTML 兼容 Bootstrap CSS 框架.
带条件的分页 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
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、父模板定义片段 。
1
2
3
|
@section(
'part'
)
// 中间内容即使是一个片段
@show
|
2、子模板填充片段 。
1
2
3
|
@section(
'part'
)
// 片段填充内容(后台的表单、列表等)
@endsection
|
1.3 占位 。
1、父模板占位 。
@yield('title') 。
2、子模板填充占位 。
第一种填充(文本): 。
@section('title' , '填充的文本占位') 。
第二种填充(文本 or html) 。
1
2
3
|
@section(
'title'
)
// 填充的占位
@endsection
|
1.4 组件、插槽 。
1、定义组件 。
1
2
3
4
5
6
7
|
// 路径:Laravel/resources/views/component.blade.php
<div
class
=
'component'
>
<!--
$title
,
$content
变量实际上就是预定义的插槽 -->
<div
class
=
'title'
>{{
$title
}}</div>
<div
class
=
'content'
>{{
$content
}}</div>
</div>
|
2、使用组件 。
1
2
3
4
5
6
7
8
9
10
11
12
13
|
// 路径:Laravel/resources/views/test.blade.php
@component(
'component'
)
@slot(
'title'
)
组件标题
@endsolt
@slot(
'content'
)
组件内容
@endslot
@endcomponent
|
2.数据显示 。
2.1 转义输出 。
{{ $name }} 。
2.2 未转义输出 。
{!! $name !!} 。
2.3 打印内容并带一个默认值 。
{{ $var or 'default' }} 。
2.4 原格式输出 。
1
2
3
4
5
6
7
8
9
|
// 第一种(适合量不多):
@{{ name }}
// 第二种(适合量多):
@verbatim
{{ name }}
{{ sex }}
{{ age }}
@endverbatim
|
3. 流程控制 。
3.1 for 。
1
2
3
|
@
for
(
$i
= 0;
$i
< 10; ++
$i
)
{{
$i
}} <br />
@
endfor
|
3.2 foreach 。
1
2
3
|
@
foreach
(
$data
as
$k
=>
$v
)
{{
$k
}} <br />
@
endforeach
|
3.3 forelse 。
1
2
3
4
5
6
|
@
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循环开始 。
@endwhile - while循环结束 。
3.6 unless 。
@unless(condition) - unless开始 @endunless - unless结束 。
4. 使用原生 PHP 。
1
2
3
4
|
@php
// 里面写php代码
echo
"使用原生 PHP"
;
@endphp
|
5. 包含子视图 。
被包含的子视图可以引用父视图定义的所有变量。 你可以传递额外的数据到子视图 。
定义父视图 parent.blade.php,并包含子视图 child.blade.php,且传入额外数据 。
1
2
3
4
|
<!-- 包含子视图 -->
@
include
(
"child"
, [
"other"
=>
"额外数据"
])
|
总结 。
到此这篇关于laravel中blade模板带条件分页的文章就介绍到这了,更多相关laravel blade模板内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。
原文链接:https://juejin.im/post/5e5730ba51882548ff3a9a2c 。
最后此篇关于详解laravel中blade模板带条件分页的文章就讲到这里了,如果你想了解更多关于详解laravel中blade模板带条件分页的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我已经安装了 composer,但是查看 Laravel 文档,我正在努力解决: “确保将 ~/.composer/vendor/bin 目录放在您的 PATH 中,以便在您的终端中运行 larave
我想在迁移时插入外键而不是在 1 中添加外键值 `public function up() { Schema::table('users', function (Bluepri
这是一个open bug on Github对于 laravel-mongodb 包,但没有任何反应。也许有人知道解决方案..? 选择作为单个文档时,日期显示为日期 { "_id": "5ca
我有一个 Laravel 应用程序,我将其用作 Joomla 中构建的更大应用程序的 API。我真的很喜欢使用 Laravel,并决定在 Joomla 应用程序中使用 Eloquent。我通过在 La
我有两个 Laravel 应用程序使用相同的数据库,因此具有相同的用户和密码。 假设应用程序称为 A 和 B。 如果用户登录 A,我该怎么做才能让他们自动登录 B?因此,如果他们登录到 A,那么当他们
我正在 github 上查看 Laravel 的源代码并注意到有一个 laravel/laravel和一个 laravel/framework .它们都链接到 Laravel 网站上的相同文档,并声明
我正在尝试将 laravel 从 5.4 版本更新到 5.5。我已经按照 Laravel 指南的指示完成了所有操作: https://laravel.com/docs/master/upgrade 当
我尝试从 foreach 向每个用户添加一些新值,但因为我使用 get,现在我不能在响应中使用分页,但我还需要向每个用户添加这些值。有什么想法吗? public function statistics
我有一个链接到销毁按钮的删除链接 $task->id ,'method'=>'DELETE'] ) }}"> delete 这是销毁函数 public function destroy($i
我想在 Laravel 中上传一组文件,但我不确定文件的路径和存储对象。八现在数据已存储,但在我的情况下路径是#。在下图中,我有从前面发送的数据(Vuejs 和我正在使用 vue-upload-com
在使用三向数据透视表时,我很难在 Laravel 中进行预加载。数据库设置如下: +-------+--------+-------+-------------+ | deals | venues |
我一直在从事 laravel 5.7 博客项目。我想评论一篇文章。 我需要实现这个: 登录前,我可以在评论文本区输入任何内容 我提交评论(当然会被auth中间件拦截) 然后我被重定向到登录页面 登录后
我正在尝试为我的应用程序中的文件创建一个临时 URL。我能够将文件上传到 S3 存储桶,并且能够使用方法 \Storage::temporaryUrl($this->url, now()->addHo
如果将 Eloquent 模型作为输入传递给 Laravel 排队作业,但模型在作业在队列中运行之前被删除,会发生什么情况? 例如,我正在使用 Laravel 5.2 构建一个电子商务网站,客户可以在
我正在尝试运行在测试运行之前将数据输入数据库的单元测试。我已经定义了一个设置方法,它为每个我不想要的测试用例运行。设置方法执行良好,没有问题。我想要的是将数据输入数据库一次,然后由所有测试用例使用。所
美好的一天。例如,我有一个带有字段/属性的模型 People: name surname 而且模型也有这个方法: public function FullName() { return "{$
我无法理解 Laravel 存在验证在检查数据库中现有记录方面的工作原理。 例如 带有 user.id = 1 的 POST 请求 是否可以使用验证规则:'id' => 'exists:users'检
我正在使用Laravel 5.2创建站点 我想做的是 INSERT同时3行 新的3行必须包含时间戳created_at updated_at。 使用Query Builder方法insert,是的,它
我试图通过href Action 将一些数据传递给我的 Controller 。我不知道为什么,但是laravel使用 GET 方法传递数据,但是我需要一个 POST 来代替 GET 。我真的不明白为
我有一个问题,我的存储文件夹上的服务器前提每 2 天重置一次。所以我运行这些命令并得到修复: sudo chown -R $USER:www-data storage sudo chown -R $U
我是一名优秀的程序员,十分优秀!