Laravel学习笔记

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

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

<!-- 存放在 resources/views/layouts/master.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>


<!-- 存放在 resources/views/layouts/child.blade.php -->

@extends('layouts.master')

@section('title', 'Page Title')

@section('sidebar')
    @parent

    <p>This is appended to the master sidebar.</p>
@endsection

@section('content')
    <p>This is my body content.</p>
@endsection

子模板的@parent处被模板的 This is the master sidebar. 给替换掉了。注意,子模板位置的<p>This is appended to the master sidebar.</p>
并没有覆盖掉,只覆盖了@parent位置处

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

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

<div>
    @include('shared.errors')

    <form>
        <!-- Form Contents -->
    </form>
</div>

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

@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 = '<span style="color:red">Hello Word</span>';
return view('index')->with('name',$name);

那么,在视图里,{!! $name !!} 输出的是红色的 Hello Word,而{{ $name }}输出的是<span style="color:red">Hello Word</span>

5. 使用php artisan命令

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

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

1、直接写id法

<a href="/articles/{{ $article->id }}"></a>

2、使用URL函数法

<a href="{{ url('articles', $article->id) }}"></a>

3、使用控制器方法

<a href="{{ action('ArticlesController@show', [$article->id]) }}"></a>

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. 路由

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值