Laravel 中的一些概念

laravel 中的一些概念

核心概念

容器:是运行依赖和注入的场所;几乎所有服务容器的绑定都是在服务提供者中进行的。容器绑定的时候不用指定如何构建类,因为容器会通过php反射来自动解析对象。

服务提供者

一般用来在这里面绑定类到容器

facades

为应用程序的服务容器中可用的类提狗牯脑了一个 {静态的}接口。实际上,facades是服务容器中那些底层类的{静态代理},相比于传统的静态方法,facades提供了简洁且丰富的语法。

facades和依赖注入

facedes 类似于某些类的功能的门面,方便调用。依赖注入是 在类的构造方法或者set或者get方法中传入类,容器会根据情况注入类的实例。

契约 (Contracts)

其实就是接口,系统把某写功能定义为接口,以方便不同的实现。例如缓存,定义了接口之后,可以用文件缓存或者内存缓存来实现。其实,,每一个facades和契约等价。facades底层其实就是调用的契约中的实现类的实例。

契约和facades

契约,例如用在依赖注入中,明确确定了注入的类型。契约呢,他没有这种强制的类型依赖关系。

Http

命名路由:命名路由可以把一些路由使用name方法命名。之后便可以使用route直接根据name的名字生成URL

路由组:路由组的初衷是,把有相同特点的路由归一下类。例如,有些路由使用了相同的中间件、使用了相同的路由前缀、使用了相同的命名空间等。

中间件:Laravel 中间件提供了一种方便的机制来过滤进入应用的 HTTP 请求。例如登录检测、日志、CSRF保护等。

最好将中间件想象为一系列的「层」,HTTP 请求必须经过它们才会触发您的应用程序。每一层都可以检测接收的请求,甚至可以完全拒绝请求访问您的应用。

前置中间件 和 后置中间件:这个取决于你的handle方法是在$next($request)之前还是之后了。

注册中间件:
1、如果想自己的中间件让每一一个请求都经过,就在app/Http/Kernel.php中的$middleware注册
2、如果想自己指定哪一个路由使用中间件可以在app/Http/Kernel.php中的$routedMiddleware注册

控制器

使用命令创建资源控制器
php artisan make:controller PhotoController --resource --model=Photo

路由缓存:非匿名方法路由可以生成缓存!命令如下,生产之后有助于提高效率
php artisan route:cache

请求

在 Laravel 的全局中间件中默认包含了 TrimStrings 和 ConvertEmptyStringsToNull 两个中间件。这些中间件被列在 App\Http\Kernel 类中。它们会自动处理所有请求中传入的字符串字段,比如将空的字符串字段转变成 null 值。你再也不用担心路由和控制器中数据规范化的问题。

获取字段,并且指定默认值
$name = $request->input('name', 'Sally');

如果传输表单数据中包含「数组」形式的数据,那么可以使用「点」语法来获取数组:
$name = $request->input('products.0.name');

如果请求发送到服务器是json,且设置了 Content-Type 为 application/json
$name = $request->input('user.name');

下面的两个方法可以把请求中的指定火全部字段缓存到session,这样在前端可以取到。
$request->flash();
$request->flashOnly(['username', 'email']);

从缓存取出来旧数据:$username = $request->old('username');

响应

不仅可以返回字符串,还可以返回数组,数组会直接被转换为json,如果是Eloqute对象,也会转换为json对象。
Route::get('/', function () {
return [1, 2, 3];
});

返回json
return response()->json([
'name' => 'Abigail',
'state' => 'CA'
]);

视图合成器

可以在渲染视图的时候有一个回调。让你可以在这个时候给视图绑定一些数据。所以,一些公用组件,可以用这个,避免逻辑在多个地方重新写。

Session

除了可以在控制器方法中获取session之外,还有一个辅助方法
// 获取 Session 中的一条数据...
$value = session('key');

// 指定一个默认值...
$value = session('key', 'default');

// 存储一条数据至 Session 中...
session(['key' => 'value']);

表单验证

可以使用,如下的内置方法来验证
public function store(Request $request)
{
$this->validate($request, [
'title' => 'required|unique:posts|max:255',
'body' => 'required',
]);

// 文章内容是符合规则的,存入数据库

}

当然,也可以使用php artisan make:request StoreBlogPost创建一个表单请求,在StoreBlogPost定义验证规则,然后就可以
public function store(StoreBlogPost $request)
{
// The incoming request is valid...
}

模板

1、@section 和 @yield 命令。 @section 命令正如其名字所暗示的一样是用来定义一个视图区块的,而 @yield 指令是用来显示指定区块的内容的。
2、@@parent 命令会在视图被渲染时替换为布局中的内容为父布局。
3、组件 & Slots 。Slots是组件中的一个占位符
4、模板语法
简单显示:Hello, {{ $name }}.
函授调用:The current UNIX timestamp is {{ time() }}.
三元符号:{{ $name or 'Default' }}
显示不经过转义的字符串:Hello, {!! $name !!}.
注释:{{-- 此注释将不会出现在渲染后的 HTML --}}

5、if语句
@if (count($records) === 1)
我有一条记录!
@elseif (count($records) > 1)
我有多条记录!
@else
我没有任何记录!
@endif

你可能感兴趣的:(Laravel 中的一些概念)