Laravel教程 八:queryScope 和 setAttribute

此文章为原创文章,未经同意,禁止转载。

直接就是按照上一节所说的那样,我们来说说queryScope和setAttribute在laravel的用法。

关于应用场景

这里我首先是想向大家简单说说这两个知识点得应用场景是什么,我们在开发的时候,总是希望有一种偷懒的方式,所以考虑以下这两个场景:

  1. 数据在存入数据库的时候需要进行预先处理,比如考虑一个简单地例子:我们在保存用户的登录密码的时候,都是需要将密码用某种方式加密过后在写入数据库的,我们难道在每一次在提交表单过来之后都对传过来的数据进行一次数据加密么?能不能有一种自动完成对密码入库前就加密的机制呢?这样我们在处理表单的时候就不用关心密码加密的问题了
  2. 想一想我们在向用户展示的数据是不是基本上都是从数据库取的呢?那么往往我们会有很多的查询语句,在这样的情况之下很多的查询语句可以就会重复,但是在写代码这一行中,一旦出现多个重复,基本上就会有优化方式存在,所以这个时候queryScope就派上用场了

setAttributes

之前,我们都是将published_at设置为文章创建的日期:

  1. $input['published_at'] = Carbon::now();

然而这并不是我们想要的,我们希望有一种可以控制的方式,比如在表单之中设置文章的发布日期,所以,我们来实现一下:首先将published_at这个字段放到我们的form之中,在create.blade.php中,加入published_at 输入框输入:

  1. <div class="form-group">
  2. {!! Form::label('published_at','发布日期') !!}
  3. {!! Form::input('date','published_at',date('Y-m-d'),['class'=>'form-control']) !!}
  4. </div>

这一段代码加在textarea后面,这里使用了Form::input(),这个方法,因为Form这个类没有类似Form::date()指定date的方法,所以我们使用Form::input()并指定input的类型为date,并使用date('Y-m-d')来指定默认值为文章发布当天,但是我们可以修改,我们来看看我们的页面现在是什么样的:

这里我们可以看到我们拿到了published_at这个字段了,这个时候,可以修改一下ArticleController中的store()方法的代码了:

  1. $input = $request->all();
  2. $input['intro'] = mb_substr($request->get('content'),0,64);
  3. Article::create($input);
  4. return redirect('/');

我们删除了$input['published_at'] = Carbon::now();这一行代码,然后尝试创建一篇文章来看看:

OK,到这里,文章可以创建成功了,但是如果我们看看数据库当中的数据:

这里的日期设置成的格式并不是理想的模式,有没有一种方式可以将其设置为跟created_atupdated_at一样的呢?时分秒都可以知道的呢?这个时候就可以使用setAttribute来完成了,在Article.php中添加下面的方法:

  1. public function setPublishedAtAttribute($date)
  2. {
  3. $this->attributes['published_at'] = Carbon::createFromFormat('Y-m-d',$date);
  4. }

这里注意这个写法set+字段名+Attribute,还有的就是使用驼峰法。比如你要加密密码的时候可以这样:

  1. public function setPasswordAttribute($passowrd)
  2. {
  3. $this->attributes['password'] = Hash::make($passowrd);
  4. //仅仅是举例
  5. }

这里我们使用了Carbon这个类,因为我们还想将published_at字段作为Carbon对象来处理,这样后期会有很大的好处。注意在文件头部使用use Carbon\Carbon;来引入Carbon。这个时候我们再来发表一次:

再来看看数据库:

这样一来格式是对了,那么再来为Article.php添加一行代码使published_at作为Carbon对象来处理:

  1. protected $dates = ['published_at'];

对这样就完成了,关于更多地Carbon好处和使用特性,我们在后面再说。

queryScope

上面实现了用published_at实现了文章的发布日期,但是现在的文章展示还是原来的样式,这并不是我们想要的结果,因为我们刚刚设置发表日期为9-12的文章(写文章的时候为9-08)也展示出来了,我们得限制一下。首先我们可以在查询的时候直接实现,比如在ArticleControllerindex()方法中将查询语句写成这样:

  1. $articles = Article::where('published_at','<=',Carbon::now())->latest()->get();

我们使用where()直接限制published_at时间小于或等于当前时间的文章才进行显示,看看效果:

发现在未来时间发布的文章确实隐藏了,这样貌似已经达到了目的,为什么还要引入qeuryScope这个用法呢?这是因为考虑到代码的重用性,比如我们要是多个地方使用到Article::where('published_at','<=',Carbon::now())这个条件限制呢,我们有没有一种方式可以将查询语句写成类似下面这种形式呢?

  1. $articles = Article::latest()->published()->get();

就是直接使用published()这个自定义的方法来代替where('published_at','<=',Carbon::now())呢,这样代码可读性也会更好。

所以我们就来说说,queryScope的用法了,想想我们之前设置published_at这个字段的目的:

  1. 我们希望可以对文章进行简单地管理,比如我们在写系列文章的时候,有可能一天写了好几篇,但是这种时候其实我们发一篇文章就好了,每天消化一篇文章就很不错了,所以作为作者,我并不想还没到发布日期的文章就展示给用户看,但是,我写了文章也想把它存入数据库,让它在该发布的日期自动显示,这样就好了。于是,我们可以好好利用一下published_at这个字段

在我们的Article.php中增加下面的方法:

  1. public function scopePublished($query)
  2. {
  3. $query->where('published_at','<=',Carbon::now());
  4. }

这里注意一下写法scope+自定义的方法名字,还有就是一如既往的驼峰法。比如我们想使用published()这个方法,就定义为scopePublished($query)。这个时候就可以真正的使用上面说的查询了,在ArticleControllerindex()方法中:

  1. $articles = Article::latest()->published()->get();

再去看看效果,相信你刷新之后还是一样的。

总结

又是最后的结尾了,这里我们简单的介绍了queryScope和setAttribute的用法,下一节打算说说Eloquent的一个重要的内容:Eloquent Relationship。那个时候也就会越来越觉得laravel的强大了。

最后:Happy Hacking

Laravel教程 八:queryScope 和 setAttribute的更多相关文章

  1. Laravel教程 七:表单验证 Validation

    Laravel教程 七:表单验证 Validation 此文章为原创文章,未经同意,禁止转载. Laravel Form 终于要更新这个Laravel系列教程的第七篇了,期间去写了一点其他的东西. 就 ...

  2. CRL快速开发框架系列教程八(使用CRL.Package)

    本系列目录 CRL快速开发框架系列教程一(Code First数据表不需再关心) CRL快速开发框架系列教程二(基于Lambda表达式查询) CRL快速开发框架系列教程三(更新数据) CRL快速开发框 ...

  3. 2016 版 Laravel 系列入门教程(三)【最适合中国人的 Laravel 教程】

    本教程示例代码见: https://github.com/johnlui/Learn-Laravel-5 在任何地方卡住,最快的办法就是去看示例代码. 在本篇文章中,我们将尝试构建一个带后台的简单博客 ...

  4. Laravel教程 六:表单 Forms

    Laravel教程 六:表单 Forms 此文章为原创文章,未经同意,禁止转载. Form laravel 5.2 之后请使用 laravelcollective/html 替换 illuminate ...

  5. Laravel教程 四:数据库和Eloquent

    Laravel教程 四:数据库和Eloquent 此文章为原创文章,未经同意,禁止转载. Eloquent Database 上一篇写了一些Laravel Blade的基本用法和给视图传递变量的几种方 ...

  6. Laravel教程 五:MVC的基本流程

    Laravel教程 五:MVC的基本流程 此文章为原创文章,未经同意,禁止转载. Controller 期间受到很多私事影响,终于还是要好好写写laravel的教程了. 上一篇我们说了数据库和Eloq ...

  7. Laravel教程 三:视图变量传递和Blade

    Laravel教程 三:视图变量传递和Blade 此文章为原创文章,未经同意,禁止转载. Blade 上一篇我们简单地说了Router,Views和Controllers的工作流程,这一次我就按照上一 ...

  8. Laravel教程 一:安装及环境配置

    Laravel教程 一:安装及环境配置 此文章为原创文章,未经同意,禁止转载. Homestead 最近在SF上面看到越来越多的Laravel相关的问题,而作为一个Laravel的脑残粉,本来打算有机 ...

  9. Laravel教程 二:路由,视图,控制器工作流程

    Laravel教程 二:路由,视图,控制器工作流程 此文章为原创文章,未经同意,禁止转载. View Controller 上一篇教程我们走了那么长的路,终于把Laravel安装好了,这一篇教程我们就 ...

随机推荐

  1. trac项目管理平台

    本文来自百科,由于是非Python开发者,所以仅为了拓宽知识面 1软件介绍 Trac是一个为软件开发项目需要而集成了Wiki和问题跟踪管理系统的应用平台,是一个开源软件应用.Trac以简单的方式建立了 ...

  2. usb驱动开发2之代码地图

    USB只是Linux庞大家族里的一个小部落,host controller是它们的族长,族里的每个USB设备都需要被系统识别.下图显示包含一个USB接口的USB鼠标导出的结果. USB系统中的第一个U ...

  3. .net程序集强命名(签名)

    要想得到强签名的dll有两种情况: 1.给项目添加强命名 在你的项目右键->属性->签名,勾选“为程序集签名”,新建 或 浏览已经新建过的.pfx文件,然后重新build项目,生成的dll ...

  4. Linux Shell编程三

    case分支条件语句. case "string" in pattern_1) commands ;; pattern_2) commands ;; *) commands ;; ...

  5. [转]开发Visual Studio风格的用户界面--MagicLibrary使用指南

    本文的示例代码为可以从这里下载: 1           概述 微软Visual Studio.NET开发工具推出已经好几年了,这个开发工具一推出就以其易用性和强大功能深受开发者的喜爱.尤其是.NET ...

  6. 抓包工具charles的使用

    Charles是一款抓包修改工具,数据请求控制容易,操作简单. 下载和安装 首先是工具下载和安装 安装前需要先有Java的运行环境.下载到charles的破解版以后,正常安装.一般破解版里会有char ...

  7. JS案例之8——从一个数组中随机取数

    近期项目中遇到一个需求,从一个列表中随机展示列表的部分内容,需求不大,JS也非常容易实现.主要是运用到了Math对象的random方法,和Array的splice方法. 思路是先新建一个数组,存放所有 ...

  8. pythonchallenge(三)

    PythonChallenge_3 一.实验说明 1. 环境登录 无需密码自动登录,系统用户名shiyanlou,密码shiyanlou 2. 环境介绍 本实验环境采用带桌面的Ubuntu Linux ...

  9. 20145208 《Java程序设计》第8周学习总结

    20145208 <Java程序设计>第8周学习总结 教材学习内容总结 NIO与NIO2 NIO与IO的区别 IO           NIO 面向流             面向缓冲 阻 ...

  10. Android开发的那些坑和小技巧

    1.android:clipToPadding 意思是控件的绘制区域是否在padding里面.默认为true.如果你设置了此属性值为false,就能实现一个在布局上事半功陪的效果.先看一个效果图. 上 ...