Laravel学习笔记

1. 模板页上的内容覆盖子页面上的内容

在子页面中可以使用 @parent 指令来显示模板页上的内容,前提是在布局模板中使用@section指令用来指定覆盖的区域



    
        App Name - @yield('title')
    
    
        @section('sidebar')
            This is the master sidebar.
        @show

        
@yield('content')
@extends('layouts.master') @section('title', 'Page Title') @section('sidebar') @parent

This is appended to the master sidebar.

@endsection @section('content')

This is my body content.

@endsection

子模板的@parent处被模板的 This is the master sidebar. 给替换掉了。注意,子模板位置的

This is appended to the master sidebar.


并没有覆盖掉,只覆盖了@parent位置处

2. 在视图中引入另外一个视图

在使用@include指令引入一个视图,所引入视图中的变量等,在本视图中依然有效

@include('shared.errors')

尽管被包含的视图继承所有父视图中的数据,还可以传递额外参数到被包含的视图:

@include('view.name', ['some' => 'data'])

注:不要在 Blade 视图中使用 __DIR____FILE__ 常量,因为它们会指向缓存视图的路径。

3. blade模板引擎的特殊用户

@{{ $name }} 不使用{{}}进行解析。主要针对有些前端框架使用的也是{{}}
{{ $name or 'Default'}} 表示如果给定的值($name)没有的话,使用默认值(Default)
{{ isset($name)?$name:'Default' }} 用法同上,三目运算
@unless 除非的意思。除非是怎么样,否则的话才会输出
例:

@unless($score > 60)
    不及格
@endunless

如果分数大于60的话不执行里面的语句,否则的话才会输出。如果分数大于60不输出内容,小于60输出不及格

4. {{}}{!! !!}的区别

{!! !!} 对代码会进行转义, `{{}}不会对代码进行转义
比如有一个变量,存储的是一段HTML标签或者JS,那么{{}}会直接输出这些进行显示,而{!! !!}会把它当作HTML进行解析

例:在一个控制器内

$name = 'Hello Word';
return view('index')->with('name',$name);

那么,在视图里,{!! $name !!} 输出的是红色的 Hello Word,而{{ $name }}输出的是Hello Word

5. 使用php artisan命令

1、 使用 php artisan make:model --migration Post
会在app目录下创建模型类 post
会在database/migrations目录下创建 post迁移用数据库

6. 在视图中显示URL连接的三种方式

1、直接写id法

2、使用URL函数法

3、使用控制器方法

7. module特殊用法

1、使用 setFieldNameAttribute 可以在数据存入数据库之前,对数据进行处理,中间的fieldName为要处理的字段名

例:

class Article extends Model
{
    protected $fillable = ['title', 'content', 'published_at'];
    public function setPublishedAtAttribute($date){
        $this->attributes['published_at'] = Carbon::createFromFormat('Y-m-d', $date);
    }
}

上面这个例子表示在存入数据库之前,对published_at字段进行处理。把接收到的时间字段给处理后,在存入数据库
前面的set和后面的Attribute为关键字,中间的字段名为驼峰写法

2、 使用 scopeMethodName 定义一个查询语句用方法

例:

//Controller里使用
$articles = Article::latest()->published()->get();  //使用了自定义的published方法
//model里
public function scopePublished($query)   //$query 表示传入进来的查询语句
{
    $query->where('published_at', '<=', Carbon::now());   //表示查询时间小于或等于当前时间的数据
}

注意scope为关键字,后面方法名为驼峰法,第一个字母大写,需要接收查询语句擦拭,但是不需要再使用的时候传递。

8. Carbon类的使用

如果想把自己定义的时间字段作为Carbon对象进行使用的话,需要在控制器内定义一个属性 $dates
然后把字段名赋值给 $dates
例:

class Article extends Model
{
    protected $fillable = ['title', 'content', 'published_at'];
    protected $dates = ['published_at'];
}
Carbon::now() 表示输出当前时间

9. 自动生成的created_at字段用法

自动生成的这个字段不属于普通的时间,而是作为一种Carbon对象来存储的

1、使用$article->created_at,输出的是Carbon对象

2、使用$article->created_at->year,输出的是年份

3、使用$article->created_at->diffForHumans(),输出的是多少时间前发布的

10. 路由的参数筛选

路由里的接收的参数可以使用正则进行过滤,使用正则可以匹配给定过来的参数是否符合规则
例:

Route::get('user/{name}', function ($name) {
    //
})->where('name', '[A-Za-z]+');

11. ENV配置

config/app.php 里可以直接更改env里的配置为什么还需要在env文件里填配置。
通过代码可以发现,它是优先调用evn里的配置,如果存在的话,直接使用env里的配置,如果不存在才会使用本文件里的配置。
好处是,可以在.git上把env文件给屏蔽掉,这样其它人在使用的时候不清楚数据库的真实地址和用户名

12. 路由

路由文件里为什么每条路由写一次,这样有什么好处?
每条路由写一次利于管理,特别在一个请求比较多的情况下可以知道每个文件的请求。
在重构的时候也可以很方便的知道哪些是没用可以删掉的请求。

你可能感兴趣的:(Laravel学习笔记)