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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • MongoVUE_Vue.js+Flask+MongoDB

    MongoVUE_Vue.js+Flask+MongoDBmongovue是mogodb的一个可视化操作工具,下面介绍一下这个工具的一些简单应用1首先进入连接的界面,在此页面中,选择+,则会进人数据库信息填写2此页面为数据库链接填写界面,name随便取一个,server,填写服务器的ip地址,port填写服务器端口号,后面则是填写密码和用户 3,正常链接后,则会显示相应的库,双击选择要连接的库4 点击右上角的fin

    2022年8月21日
    9
  • delphi 字符串函数_C语言字符串函数

    delphi 字符串函数_C语言字符串函数QueueUserWorkItem函数Windows说明如下:一、异步调用函数:BOOLQueueUserWorkItem(PTHREAD_START_ROUTINEpfnCallback,PVOIDpvContext,ULONGdwFlags);该函数将“工作项目”放入线程池并且立即返回。工作项目是指一个用pfnCallback参数标识的函数。它被调用并且传递…

    2025年12月5日
    4
  • 单模光纤的传输距离比多模光纤的传输距离_单模多模单模光纤传感器

    单模光纤的传输距离比多模光纤的传输距离_单模多模单模光纤传感器1.1000Base-SX及1000Base-LX是什么意思?短波长光传输1000Base-SX、长波长光传输1000Base-LX多模光纤可以分为长波激光(称为1000BaseLX)和短波激光(称为1000BaseSX)。2.千兆位以太网标准问题:请问多模和单模光纤的极限传输距离是多少?标准光纤类型光纤直径(μm)最大传输距离1000base-sx多模62.5260m1000base-sx…

    2022年8月30日
    4
  • JedisPool_redis scan

    JedisPool_redis scan前面给大家介绍了Redis的使用,今天将为大家介绍一下我们的JedisPool,那么Jedis是什么和为什么要使用它呢?请看下文:一、为什么要引入JedisPool?           首先我们如果每次使用缓存都生成一个Jedis对象的话,这样意味着会建立很多socket连接,造成系统资源被不可控调用,    甚至会导致奇怪错误的发生。如果使用单例模式,在线程安全模式下

    2025年9月15日
    8
  • C++宏和枚举

    宏我们的计算器程序,用1234对应加减乘除,对于人阅读很产生一点障碍。隔一个月后再看此代码可能想不起是0123还是1234了,还得去代码中查找,如果能为代表四则运算的四个数取个有意义的别名就好了,一

    2021年12月24日
    53
  • sql中decode的用法_sql求和函数

    sql中decode的用法_sql求和函数decode()函数的语法:其中:columnname为要选择的table中所定义的column;缺省值可以是你要选择的columnname本身,也可以是你想定义的其他值,比如Other等;

    2022年8月1日
    16

发表回复

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

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