laravel学习教程之存取器


Posted in PHP onJuly 30, 2016

前言

Laravel是一个简单优雅的PHP Web开发框架,可以将开发者从意大利面条式的代码中解放出来,通过简单、高雅、表达式语法开发出很棒的Web应用,那下面跟着小编一起来学习laravel中的存取器吧。

Eloquent: 存取器简介

访问器和存储器允许你在获取或者设置 Eloquent 模型属性值时对其进行格式化操作。比如,你可能希望当一个值存储进数据库之前先对其进行 Laravel encrypter 进行加密操作,并且可以在你通过模型访问的时候自动的进行该属性的解密。

除了可自定义的的访问器和存储器,Eloquent 也可以自动的将日期字段转换为 Carbon 实例,或者甚至是将字符串字段转换为 JSON

访问器 & 存取器

定义一个访问器

为了定义一个访问器,你需要在你的模型上创建一个 getFooAttribute 方法,其中的 Foo 是你需要进行访问的列名的驼峰方式的命名。在这个例子中,我们将定义一个 first_name 属性的访问器。这个访问器会在 Eloquent 尝试获取 first_name 属性值时触发:

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class User extends Model
{
 /**
  * Get the user's first name.
  *
  * @param string $value
  * @return string
  */
 public function getFirstNameAttribute($value)
 {
  return ucfirst($value);
 }
}

就如你所看到的,属性原始的值会被传递到访问器中,这允许你对原始值进行操作及返回格式化后的值。你只需要简单的访问 first_name 属性就可以从存取器中访问该值:

$user = App\User::find(1);

$firstName = $user->first_name;

定义一个存储器

为了定义一个存储器,你需要在你的模型上定义一个 setFooAttribute 方法,其中的 Foo 是你期望访问的列的驼峰样式的名称。那么,这一次,让我们为 first_name 属性定义一个存储器。这个存储器会在模型尝试设置 first_name 属性的值时进行调用:

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class User extends Model
{
 /**
  * Set the user's first name.
  *
  * @param string $value
  * @return string
  */
 public function setFirstNameAttribute($value)
 {
  $this->attributes['first_name'] = strtolower($value);
 }
}

存储器会接收即将设置到属性中的值,这允许你对这个值进行操作,并将其设置到模型内部的 $attributes 属性中。所以,举个示例,如果我们尝试将 first_name 属性设置为 Sally:

$user = App\User::find(1);

$user->first_name = 'Sally';

在这个例子中,setFirstNameAttribute 方法会被调用并伴随 Sally 值。存储器会应用 strtolower 方法将名字小写化然后将值设置到内部的 $attributes 数组中。

日期存取器

默认的,Eloquent 会转换 created_at updated_at 列为 Carbon 实例,这个实例可以提供多种有用的方法,并且它继承自原生 PHP 的 DataTime 类。

你可以自定义哪些字段可以进行自动的转换,甚至是完全禁用这种转换,你需要在你的模型中复写 $dates 属性:

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class User extends Model
{
 /**
  * The attributes that should be mutated to dates
  *
  * @var array
  */
 protected $dates = ['created_at', 'updated_at', 'deleted_at'];
}

当一列被认为是日期时,你可以将其设置为 UNIX 时间戳,日期字符串(Y-m-d),时间字符串,和 DateTime / Carbon 实例,并且日期的值会自动的正确的存储到数据库中:

$user = App\User::find(1);

$user->deleted_at = Carbon::now();

$user->save();

就如上面所述,当获取的属性是 $dates 属性所列出的值之一时,它会自动的被转换为 Carbon 实例,这允许你在属性上使用 Carbon 的一些方法:

$user = App\User::find(1);

return $user->deleted_at->getTimestamp();

默认的,时间戳被格式化为 Y-m-d H:i:s 的格式。如果你希望自定义时间戳的格式,你需要在你的模型中设置 $dateFormat 属性。该属性将确定日期属性将如何存储到数据库中以及当模型进行序列化或者 JSON 化时如何展示:

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class Flight extends Model
{
 /**
  * The storage format of the model's date columns.
  *
  * @var string
  */
 protected $dateFormat = 'U';
}

属性转换

你可以在你的模型中定义 $casts 属性来提供一种方便的方式将属性转换为通用的数据类型。$casts 属性应该是一个数组,并且其每一项的键应该是需要进行转换的属性名,而其键所对应的值应该是你需要属性转换到的类型。支持的转换类型有:integerrealfloatdoublestringbooleanobjectarraycoolectiondatedatetime,和 timestamp

比如,让我们转换 is_admin 属性,它在数据库中存储的值为一个整型(0 或者 1),我们将其转换为布尔值:

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class User extends Model
{
 /**
  * The attributes that should be casted to native types.
  *
  * @var array
  */
 protected $casts = [
  'is_admin' => 'boolean',
 ];
}

现在,每当你访问 is_admin 属性时,其值都会被转换为布尔值,即使其在数据库中存储的整型值:

$user = App\User::find(1);

if ($user->is_admin) {
 //
}

数组转换

array 转换的类型对于存储序列化 JSON 值的列尤其有用。比如,如果数据库有一个 TEXT 类型的字段,并且其存储的是序列化的 JSON,如果你添加该属性的 array 转换,那么当你在 Eloquent 模型上访问这个属性时,它将会自动的进行反序列化为 PHP 的数组:

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class User extends Model
{
 /**
  * The attributes that should be casted to native types.
  *
  * @var array
  */
 protected $casts = [
  'options' => 'array'
 ];
}

当你转义定义完成之后,你可以访问 options 属性,并且它会自动的被从 JSON 反序列化为 PHP 数组。当你设置值到 options 属性时,所给定的数组会自动的序列化为 JSON 格式,然后进行存储:

$user = App\User::find(1);

$options = $user->options;

$options['key'] = 'value';

$user->options = $options;

$user->save();

以上就是小编为大家整理的laravel学习教程之存取器的全部内容,有需要的小伙伴们可以参考学习,小编陆续还会更新laravel相关的知识,请大家继续关注三水点靠木。

PHP 相关文章推荐
PHP安全配置
Dec 06 PHP
PHP XML操作类DOMDocument
Dec 16 PHP
PHP 作用域解析运算符(::)
Jul 27 PHP
php继承的一个应用
Sep 06 PHP
destoon切换城市后实现logo旁边显示地区名称的方法
Aug 21 PHP
php提取字符串中网站url地址的方法
Dec 03 PHP
php去除字符串中空字符的常用方法小结
Mar 17 PHP
PHP动态生成指定大小随机图片的方法
Mar 25 PHP
php微信开发接入
Aug 27 PHP
PHP实现双链表删除与插入节点的方法示例
Nov 11 PHP
php单元测试phpunit入门实例教程
Nov 17 PHP
thinkphp5使用无限极分类
Feb 18 PHP
thinkphp表单上传文件并将文件路径保存到数据库中
Jul 28 #PHP
thinkphp验证码的实现(form、ajax实现验证)
Jul 28 #PHP
Thinkphp3.2.3分页使用实例解析
Jul 28 #PHP
thinkphp3.2.3 分页代码分享
Jul 28 #PHP
php实现带读写分离功能的MySQL类完整实例
Jul 28 #PHP
PHP实现带重试功能的curl连接示例
Jul 28 #PHP
php使用strip_tags()去除html标签仍有空白的解决方法
Jul 28 #PHP
You might like
关于使用coreseek并为其做分页的介绍
2013/06/21 PHP
PHP面向对象之事务脚本模式(详解)
2017/06/07 PHP
setTimeout自动触发一个js的方法
2014/01/15 Javascript
Javascript原型链和原型的一个误区
2014/10/22 Javascript
AngularJS入门教程之Hello World!
2014/12/06 Javascript
js实现用户离开页面前提示是否离开此页面的方法(包括浏览器按钮事件)
2015/07/18 Javascript
Bootstrap实现下拉菜单效果
2016/04/29 Javascript
domReady的实现案例
2016/11/23 Javascript
angularjs点击图片放大实现上传图片预览
2017/02/24 Javascript
jquery.validate.js 多个相同name的处理方式
2017/07/10 jQuery
JavaScript中关于class的调用方法
2017/11/28 Javascript
深入浅析JS中的严格模式
2018/06/04 Javascript
快速解决处理后台返回json数据格式的问题
2018/08/07 Javascript
Vue.js图片预览插件使用详解
2018/08/27 Javascript
JS中判断字符串存在和非空的方法
2018/09/12 Javascript
微信端调取相册和摄像头功能,实现图片上传,并上传到服务器
2019/05/16 Javascript
Vue请求java服务端并返回数据代码实例
2019/11/28 Javascript
python清除字符串里非字母字符的方法
2015/07/02 Python
利用Python获取操作系统信息实例
2016/09/02 Python
用pandas中的DataFrame时选取行或列的方法
2018/07/11 Python
tensorflow保持每次训练结果一致的简单实现
2020/02/17 Python
为女性购买传统的印度服装和婚纱:Kalkifashion
2019/07/22 全球购物
铭宣海淘转运:美国、日本、英国转运等全球转运公司
2019/09/10 全球购物
澳大利亚在线购买葡萄酒:The Wine Collective
2020/02/20 全球购物
mysql_pconnect()和mysql_connect()有什么区别
2012/05/25 面试题
Does C# support multiple inheritance? (C#支持多重继承吗)
2012/01/04 面试题
产品生产计划书
2014/05/07 职场文书
先进员工获奖感言
2014/08/14 职场文书
党支部班子“四风”问题自我剖析材料
2014/09/28 职场文书
高校师德师风自我剖析材料
2014/09/29 职场文书
2014年劳动部工作总结
2014/12/11 职场文书
2015年生产车间工作总结
2015/04/22 职场文书
canvas绘制折线路径动画实现
2021/05/12 Javascript
python 爬取哔哩哔哩up主信息和投稿视频
2021/06/07 Python
漫画「你在春天醒来」第10卷封面公开
2022/03/21 日漫
小程序实现侧滑删除功能
2022/06/25 Javascript