Laravel 5框架Mutator,Scope

Laravel 5框架Mutator,Scope首先修改控制器:publicfunctionstore(){Article::create(Request::all());returnredirect(‘articles’);}然后修改视图,添…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

首先修改控制器:

public function store() {   Article::create(Request::all());   return redirect(‘articles’); } 

然后修改视图,添加发布日期字段

@extends(‘layout’)   @section(‘content’)  

Write a New Article

   


    {
{–使用我们添加的 illuminate\html 开源库–}}   {!! Form::open([‘url’ => ‘articles’]) !!}    

      {!! Form::label(‘title’, ‘Title:’) !!}       {!! Form::text(‘title’, null, [‘class’ => ‘form-control’]) !!}    

     

      {!! Form::label(‘body’, ‘Body:’) !!}       {!! Form::textarea(‘body’, null, [‘class’ => ‘form-control’]) !!}    

     

      {!! Form::label(‘published_at’, ‘Publish On:’) !!}       {!! Form::input(‘date’, ‘published_at’, date(‘Y-m-d’), [‘class’ => ‘form-control’]) !!}    

     

      {!! Form::submit(‘Add Article’, [‘class’ => ‘btn btn-primary form-control’]) !!}    

    {!! Form::close() !!}   @stop 

可以添加一个mutator(也就是其他语言的属性设置器),修改我们的model

<?php namespace App;   use DateTime; use Illuminate\Database\Eloquent\Model;   class Article extends Model {    protected $fillable = [     ‘title’,     ‘body’,     ‘published_at’  ];     //属性设置其要遵守格式约定   // set属性Attribute   public function setPublishedAtAttribute($date) {     $this->attributes[‘published_at’] = Carbon::createFromFormat(‘Y-m-d’, $date)->hour(8)->minute(0)->second(0);   }   } 

添加一个新的纪录,查看数据库,我们已经将时间设置正确了,但是我们的首页仍然显示未来的才发布的文章,我们修改它。

 public function index() {    //$articles = Article::latest(‘published_at’)->get();    $articles = Article::latest(‘published_at’)->where(‘published_at’, ‘<=’, Carbon::now())->get();     return view(‘articles.index’, compact(‘articles’));  } 

上面的解决方法可以工作,但是查询语句太长了。我们可以使用 Laravel 提供的 scope ,来简化我们的工作。所谓scope可以理解为是查询过程中使用的中间查询结果,比如我们定义一个published scope,他可以返回所有当前已经发布的文章,让我们修改模型。

 //设置scope,遵守命名规则 public function scopePublished($query) {   $query->where(‘published_at’, ‘<=’, Carbon::now()); } 

修改控制器使用 scope

public function index() {    //$articles = Article::latest(‘published_at’)->get();    //$articles = Article::latest(‘published_at’)->where(‘published_at’, ‘<=’, Carbon::now())->get();    $articles = Article::latest(‘published_at’)->published()->get();     return view(‘articles.index’, compact(‘articles’));  } 

在复杂的查询中我们可以使用scope来分解我们的任务,或者复用查询。

我们来增加一个新的查询,查询所有还没有发布的文章。在模型中添加scope

public function scopeUnpublished($query) {   $query->where(‘published_at’, ‘>’, Carbon::now()); } 

修改控制器使用unpulished

public function index() {    //$articles = Article::latest(‘published_at’)->get();    //$articles = Article::latest(‘published_at’)->where(‘published_at’, ‘<=’, Carbon::now())->get();    //$articles = Article::latest(‘published_at’)->published()->get();    $articles = Article::latest(‘published_at’)->Unpublished()->get();     return view(‘articles.index’, compact(‘articles’));  } 

one more thing! 如果我们在 show 方法中使用 dd($article->published_at) 查看的结果,与 dd($article->created_at); 结果不一样,前者我们使我们自己的字段,后者是在 CreateArticleTable 中通过 $table->timestamp() 自动生成的。自动生成的字段显示出来是 Carbon类型,而我们的是字符串。使用 Crabon类型有很多的好处,例如你可以输出 dd($article->created_at->diffForHumans()); ,这种 1 hour ago 结果,但我们的published_at 不可以。怎么修改模型,告诉laravel,published_at 是日期即可。

protected $dates = [‘published_at’]; 

再次使用 dd($article->published_at->diffForHumans()); ,结果显示为 3 days from now,搞定!

部分代码源自CSDN.NET和CODEGO.NET


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/30190496/viewspace-1544038/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/30190496/viewspace-1544038/

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/194607.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • Linux下对MySql数据库备份与恢复

    Linux下对MySql数据库备份与恢复MySQL命令行导入数据库:1,将要导入的.sql文件移至bin文件下,这样的路径比较方便2,同上面导出的第1步3,进入MySQL:mysql-u用户名-p如我输入的命令行:mysql-uroot-p (输入同样后会让你输入MySQL的密码)4,在MySQL-Front中新建你要建的数据库,这时是空数据库,如新建一个名为news的目标数据库5,输入:mysq

  • 如何查看python的当前版本号

    如何查看python的当前版本号

    2021年10月22日
  • java中System.getProperty()方法详解

    java中System.getProperty()方法详解System.out.println("java版本号:"+System.getProperty("java.version"));//java版本号

  • 贪婪算法(贪心算法)「建议收藏」

    贪婪算法(贪心算法)「建议收藏」贪心算法简介:@anthor:QYX贪心算法是指:在每一步求解的步骤中,它要求“贪婪”的选择最佳操作,并希望通过一系列的最优选择,能够产生一个问题的(全局的)最优解。贪心算法每一步必须满足一下条

  • 优先级队列详解

    优先级队列详解动力节点小编来为大家进行优先级队列详解,优先级队列是一种特殊类型的队列,其中每个元素都与一个优先级值相关联。并且,元素根据其优先级提供服务。即,首先服务更高优先级的元素。但是,如果出现具有相同优先级的元素,则按照它们在队列中的顺序提供服务。分配优先级值通常,在分配优先级时考虑元素本身的值。例如,具有最高值的元素被认为是最高优先级的元素。但是,在其他情况下,我们可以假设具有最低值的元素作为最高优先级元素。我们还可以根据需要设置优先级。优先队列和普通队列的区别在队列中,执行先进先

  • cinemachine_2D Cinemachine:提示和技巧「建议收藏」

    cinemachine_2D Cinemachine:提示和技巧「建议收藏」cinemachineHaveyoubeenworkingonacamerasystemforyour2DgameforagesandwishtherewassomethinglikeCinemachinefor2D?Notmanypeopleknowaboutit,buttherealreadyis!Thisblogpost…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号