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/

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 1、Java从入门到精通

    1、Java从入门到精通将自己学习的Java基础整理出来,方便复习和记忆~~一、Java的历史1、Java开发分成了3个方向JavaSE:主要用于桌面程序的开发,学习JavaEE和JavaME的基础JavaEE:主要用于网页程序的开发JavaME:主要用于嵌入式系统程序的开发2、JavaSE平台中的lib软件包Java.lang包——语言核心包java.util包——Jav…

    2022年7月8日
    19
  • Visual Studio 2019 Community 离线注册教程「建议收藏」

    Visual Studio 2019 Community 离线注册教程「建议收藏」VS2019社区版是免费的,但是需要登录微软账户,不登录只能使用30天,30天之后就无法使用了,如下图:首先使用能够访问外网的电脑登录微软账户注册VS。也可以使用我这个Licensing,直接进入第三步 找到注册文件,路径:C:\Users\{系统登录用户}\AppData\Local\Microsoft\VSCommon 将两个文件夹复制到需要注册的电脑上,路径:C:\…

    2022年10月13日
    0
  • MCMC采样_MCMC认证

    MCMC采样_MCMC认证MCMC(一)蒙特卡罗方法MCMC(二)马尔科夫链MCMC(三)MCMC采样和M-H采样MCMC(四)Gibbs采样在MCMC(三)MCMC采样和M-H采样中,我们讲到了M-H采样已经可以很好

    2022年8月5日
    6
  • 使用 SQL Server 的 uniqueidentifier 字段类型[通俗易懂]

    使用 SQL Server 的 uniqueidentifier 字段类型[通俗易懂]SQLServer自2008版起引入了 uniqueidentifier 字段,它存储的是一个UUID,或者叫GUID,内部存储为16个字节。SQLServer可用两个函数来生成 uniqueidentifier,分别是 NEWID() 和 NEWSEQUENTIALID(),后者只能用作字段的默认值。Java也有一个UUID工具类 java.uti.UUID, U…

    2022年9月7日
    0
  • 自定义事务注解[通俗易懂]

    用过spring的,应该都知道@transactional这个注解。这个注解给我们日常开发带来了很大便利,让我们无需为了数据的提交和回滚操心,只需要关注自己的业务逻辑即可。这里我模拟一下spring的注解是如何执行的。这个是项目结构首先我们需要一个数据库的连接为了保证事务的完整性,这里我们用ThreadLocal保存当前线程的数据库连接/***Createdbyzh…

    2022年4月13日
    65
  • Mysql实现RowNumber[通俗易懂]

    Mysql实现RowNumber[通俗易懂]http://www.uncletoo.com/html/mysql/1060.html

    2022年6月10日
    45

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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