[ Laravel 5.3 文档 ] 附录 —— 辅助函数

   2016-10-31 0
核心提示:1、简介Laravel自带了一系列 PHP辅助函数,很多被框架自身使用,如果你觉得方便的话也可以在代码中使用它们。2、方法列表数组函数array_add()array_add函数添加给定键值对到数组,如果给定键不存在的话:$array = array_add(['name' = 'Desk'], 'price', 100)

1、简介

Laravel自带了一系列 PHP 辅助函数,很多被框架自身使用,如果你觉得方便的话也可以在代码中使用它们。

2、方法列表

数组 函数

array_add()

array_add 函数添加给定键值对到数组,如果给定键不存在的话:

$array = array_add(['name' => 'Desk'], 'price', 100);
// ['name' => 'Desk', 'price' => 100]

array_collapse()

array_collapse 函数将多个数组合并成一个:

$array = array_collapse([[1, 2, 3], [4, 5, 6], [7, 8, 9]]);
// [1, 2, 3, 4, 5, 6, 7, 8, 9]

array_divide()

array_divide 函数返回两个数组,一个包含原数组的所有键,另外一个包含原数组的所有值:

list($keys, $values) = array_divide(['name' => 'Desk']);
// $keys: ['name']
// $values: ['Desk']

array_dot()

array_dot 函数使用”.”号将将多维数组转化为一维数组:

$array = array_dot(['foo' => ['bar' => 'baz']]);
// ['foo.bar' => 'baz'];

array_except()

array_except 方法从数组中移除给定键值对:

$array = ['name' => 'Desk', 'price' => 100];

$array = array_except($array, ['price']);
// ['name' => 'Desk']

array_first()

array_first 方法返回通过测试数组的第一个元素:

$array = [100, 200, 300];

$value = array_first($array, function ($key, $value) {
    return $value >= 150;});
// 200

默认值可以作为第三个参数传递给该方法,如果没有值通过测试的话返回默认值:

$value = array_first($array, $callback, $default);

array_flatten()

array_flatten 方法将多维数组转化为一维数组:

$array = ['name' => 'Joe', 'languages' => ['PHP', 'Ruby']];

$array = array_flatten($array);
// ['Joe', 'PHP', 'Ruby'];

array_forget()

array_forget 方法使用”.”号从嵌套数组中移除给定键值对:

$array = ['products' => ['desk' => ['price' => 100]]];

array_forget($array, 'products.desk');
// ['products' => []]

array_get()

array_get 方法使用”.”号从嵌套数组中获取值:

$array = ['products' => ['desk' => ['price' => 100]]];

$value = array_get($array, 'products.desk');
// ['price' => 100]

array_get 函数还接收一个默认值,如果指定键不存在的话则返回该默认值:

$value = array_get($array, 'names.john', 'default');

array_has()

array_has 函数使用“.”检查给定数据项是否在数组中存在:

$array = ['product' => ['name' => 'desk', 'price' => 100]];

$hasItem = array_has($array, 'product.name');

// true

$hasItems = array_has($array, ['product.price', 'product.discount']);

// false

array_last()

array_last 函数通过测试数组的最后一个元素:

$array = [100, 200, 300, 110];

$value = array_last($array, function ($value, $key) {
    return $value >= 150;
});

// 300

array_only()

array_only 方法只从给定数组中返回指定键值对:

$array = ['name' => 'Desk', 'price' => 100, 'orders' => 10];

$array = array_only($array, ['name', 'price']);
// ['name' => 'Desk', 'price' => 100]

array_pluck()

array_pluck 方法从数组中返回给定键对应的键值对列表:

$array = [
    ['developer' => ['name' => 'Taylor']],
    ['developer' => ['name' => 'Abigail']]
];

$array = array_pluck($array, 'developer.name');
// ['Taylor', 'Abigail'];

你还可以指定返回结果的键:

$array = array_pluck($array, 'developer.name', 'developer.id');
// [1 => 'Taylor', 2 => 'Abigail'];

array_prepend()

array_prepend 函数将数据项推入数组开头:

$array = ['one', 'two', 'three', 'four'];

$array = array_prepend($array, 'zero');
// $array: ['zero', 'one', 'two', 'three', 'four']

array_pull()

array_pull 方法从数组中返回并移除键值对:

$array = ['name' => 'Desk', 'price' => 100];

$name = array_pull($array, 'name');
// $name: Desk

// $array: ['price' => 100]

array_set()

array_set 方法在嵌套数组中使用”.”号设置值:

$array = ['products' => ['desk' => ['price' => 100]]];

array_set($array, 'products.desk.price', 200);
// ['products' => ['desk' => ['price' => 200]]]

array_sort()

array_sort 方法通过给定闭包的结果对数组进行排序:

$array = [
    ['name' => 'Desk'],
    ['name' => 'Chair'],
];

$array = array_values(array_sort($array, function ($value) {
    return $value['name'];
}));

/*
[
    ['name' => 'Chair'],
    ['name' => 'Desk'],
]
*/

array_sort_recursive()

array_sort_recursive 函数使用  sort 函数对数组进行递归排序:

$array = [
    [
        'Roman',
        'Taylor',
        'Li',
    ],
    [
        'PHP',
        'Ruby',
        'JavaScript',
    ],
];

$array = array_sort_recursive($array);

/*
    [
        [
            'Li',
            'Roman',
            'Taylor',
        ],
        [
            'JavaScript',
            'PHP',
            'Ruby',
        ]
    ];
*/

array_where()

array_where 函数使用给定闭包对数组进行过滤:

$array = [100, '200', 300, '400', 500];

$array = array_where($array, function ($key, $value) {
    return is_string($value);
});
// [1 => 200, 3 => 400]

head()

head 函数只是简单返回给定数组的第一个元素:

$array = [100, 200, 300];

$first = head($array);
// 100

last()

last 函数返回给定数组的最后一个元素:

$array = [100, 200, 300];

$last = last($array);
// 300

路径函数

app_path()

app_path 函数返回  app 目录的绝对路径, 你还可以使用  app_path 函数为相对于  app 目录的给定文件生成绝对路径:

$path = app_path();
$path = app_path('Http/Controllers/Controller.php');

base_path()

base_path 函数返回项目根目录的绝对路径, 你还可以使用  base_path 函数为相对于应用目录的给定文件生成绝对路径:

$path = base_path();
$path = base_path('vendor/bin');

config_path()

config_path 函数返回应用配置目录的绝对路径:

$path = config_path();

database_path()

database_path 函数返回应用数据库目录的绝对路径:

$path = database_path();

elixir()

elixir 函数返回版本控制的Elixir文件所在路径:

elixir($file);

public_path()

public_path 函数返回  public 目录的绝对路径:

$path = public_path();

resource_path()

resource_path 函数返回 resources 目录的绝对路径,还可以使用 resources 函数生成给定相对 resources 目录文件的绝对路径:

$path = resource_path();

$path = resource_path('assets/sass/app.scss');

storage_path()

storage_path 函数返回  storage 目录的绝对路径, 还可以使用  storage_path 函数生成相对于  storage 目录的给定文件的绝对路径:

$path = storage_path();
$path = storage_path('app/file.txt');

字符串 函数

camel_case()

camel_case 函数将给定字符串转化为按驼峰式命名规则的字符串:

$camel = camel_case('foo_bar');
// fooBar

class_basename()

class_basename 返回给定类移除命名空间后的类名:

$class = class_basename('Foo\Bar\Baz');
// Baz

e()

e 函数在给定字符串上运行  htmlentities

echo e('<html>foo</html>');
// <html>foo</html>

ends_with()

ends_with 函数判断给定字符串是否以给定值结尾:

$value = ends_with('This is my name', 'name');
// true

snake_case()

snake_case 函数将给定字符串转化为下划线分隔的字符串:

$snake = snake_case('fooBar');
// foo_bar

str_limit()

str_limit 函数限制输出字符串的数目,该方法接收一个字符串作为第一个参数以及该字符串最大输出字符数作为第二个参数:

$value = str_limit('The PHP framework for web artisans.', 7);
// The PHP...

starts_with()

starts_with 函数判断给定字符串是否以给定值开头:

$value = starts_with('This is my name', 'This');
// true

str_contains()

str_contains 函数判断给定字符串是否包含给定值:

$value = str_contains('This is my name', 'my');
// true

你还可以传递数组来判断给定字符串是否包含数组中的值:

$value = str_contains('This is my name', ['my', 'foo']);
// true

str_finish()

str_finish 函数添加字符到字符串结尾:

$string = str_finish('this/string', '/');
// this/string/

str_is()

str_is 函数判断给定字符串是否与给定模式匹配,星号可用于表示通配符:

$value = str_is('foo*', 'foobar');
// true
$value = str_is('baz*', 'foobar');
// false

str_plural()

str_plural 函数将字符串转化为复数形式,该函数当前只支持英文:

$plural = str_plural('car');
// cars
$plural = str_plural('child');
// children

还可以传递整型数据作为第二个参数到该函数以获取字符串的单数或复数形式:

$plural = str_plural('child', 2);
// children
$plural = str_plural('child', 1);
// child

str_random()

str_random 函数通过指定长度生成随机字符串,该函数使用了PHP的 random_bytes 函数:

$string = str_random(40);

str_singular()

str_singular 函数将字符串转化为单数形式,该函数目前只支持英文:

$singular = str_singular('cars');
// car

str_slug()

str_slug 函数将给定字符串生成URL友好的格式:

$title = str_slug("Laravel 5 Framework", "-");
// laravel-5-framework

studly_case()

studly_case 函数将给定字符串转化为单词开头字母大写的格式:

$value = studly_case('foo_bar');
// FooBar

title_case()

title_case 函数将字符串转化为 Title 形式:

$title = title_case('a nice title uses the correct case');

// A Nice Title Uses The Correct Case

trans()

trans 函数使用本地文件翻译给定语言行:

echo trans('validation.required'):

trans_choice()

trans_choice 函数翻译带拐点的给定语言行:

$value = trans_choice('foo.bar', $count);

URL函数

action()

action 函数为给定控制器动作生成URL,你不需要传递完整的命名空间到该控制器,传递相对于命名空间 App\Http\Controllers 的类名即可:

$url = action('HomeController@getIndex');

如果该方法接收路由参数,你可以将其作为第二个参数传递进来:

$url = action('UserController@profile', ['id' => 1]);

asset()

使用当前请求的 scheme(HTTP或HTTPS)为前端资源生成一个URL:

$url = asset('img/photo.jpg');

secure_asset()

使用 HTTPS 为前端资源生成一个 URL:

echo secure_asset('foo/bar.zip', $title, $attributes = []);

route()

route 函数为给定命名路由生成一个URL:

$url = route('routeName');

如果该路由接收参数,你可以将其作为第二个参数传递进来:

$url = route('routeName', ['id' => 1]);

url()

url 函数为给定路径生成绝对路径:

echo url('user/profile');
echo url('user/profile', [1]);

如果没有提供路径,将会返回 Illuminate\Routing\UrlGenerator 实例:

echo url()->current();
echo url()->full();
echo url()->previous();

其它函数

abort()

abort 函数会抛出一个被异常处理器渲染的HTTP异常:

abort(401);

还可以提供异常响应文本:

abort(401, 'Unauthorized.');

abort_if()

abort_if 函数在给定布尔表达式为 true 时抛出HTTP异常:

abort_if(! Auth::user()->isAdmin(), 403);

abort_unless()

abort_unless 函数在给定布尔表达式为 false 时抛出HTTP异常:

abort_unless(Auth::user()->isAdmin(), 403);

auth()

auth 函数返回一个认证器实例,为方便起见你可以用其取代  Auth 门面:

$user = auth()->user();

back()

back 函数生成重定向响应到用户前一个位置:

return back();

bcrypt()

bcrypt 函数使用Bcrypt对给定值进行哈希,你可以用其替代  Hash 门面:

$password = bcrypt('my-secret-password');

cache()

cache 函数可以用于从缓存中获取值,如果给定key在缓存中不存在,可选的默认值会被返回:

$value = cache('key');
$value = cache('key', 'default');

你可以通过传递数组键值对到函数来添加数据项到缓存。还需要传递缓存有效期(分钟数):

cache(['key' => 'value'], 5);
cache(['key' => 'value'], Carbon::now()->addSeconds(10));

collect()

collect 函数会根据提供的数据项创建一个集合:

$collection = collect(['taylor', 'abigail']);

config()

config 函数获取配置变量的值,配置值可以通过使用”.”号访问,包含文件名以及你想要访问的选项。如果配置选项不存在的话默认值将会被指定并返回:

$value = config('app.timezone');
$value = config('app.timezone', $default);

辅助函数 config 还可以用于在运行时通过传递键值对数组设置配置变量值:

config(['app.debug' => true]);

csrf_field()

csrf_field 函数生成一个包含 CSRF 令牌值的 HTML 隐藏域,例如,使用Blade语法:

{!! csrf_field() !!}

csrf_token()

csrf_token 函数获取当前 CSRF 令牌的值:

$token = csrf_token();

dd()

dd 函数输出给定变量值并终止脚本执行:

dd($value);
dd($value1, $value2, $value3, ...);

如果你不想停止脚本的运行,可以使用 dump 函数:

dump($value);

dispatch()

dispatch 函数推送一个新的任务到Laravel任务队列:

dispatch(new App\Jobs\SendEmails);

env()

env 函数获取环境变量值或返回默认值:

$env = env('APP_ENV');
// Return a default value if the variable doesn't exist...
$env = env('APP_ENV', 'production');

event()

event 函数分发给定事件到对应监听器:

event(new UserRegistered($user));

factory()

factory 函数为给定类、名称和数量创建模型工厂构建器,可用于测试或数据填充:

$user = factory(App\User::class)->make();

info()

info 函数会记录日志信息:

info('Some helpful information!');

还可以传递上下文数据数组到该函数:

info('User login attempt failed.', ['id' => $user->id]);

logger()

logger 函数可以用于记录 debug 级别的日志消息:

logger('Debug message');

同样,也可以传递上下文数据数组到该函数:

logger('User has logged in.', ['id' => $user->id]);

如果没有值传入该函数的话会返回 logger 实例:

logger()->error('You are not allowed here.');

method_field()

method_field 函数生成包含HTTP请求方法的HTML hidden 输入字段,例如:

<form method="POST">
    {!! method_field('DELETE') !!}
</form>

old()

old 函数获取一次性存放在 Session 中的值:

$value = old('value');
$value = old('value', 'default');

redirect()

redirect 函数返回重定向器实例进行重定向:

return redirect('/home');
return redirect()->route('route.name');

request()

request 函数返回当前请求实例或者获取一个输入项:

$request = request();
$value = request('key', $default = null)

response()

response 函数创建一个响应实例或者获取响应工厂实例:

return response('Hello World', 200, $headers);
return response()->json(['foo' => 'bar'], 200, $headers)

session()

session 函数可以用于获取/设置 Session 值:

$value = session('key');

可以通过传递键值对数组到该函数的方式设置 Session 值:

session(['chairs' => 7, 'instruments' => 3]);

如果没有传入参数到 session 函数则返回 Session 存储器对象实例:

$value = session()->get('key');
session()->put('key', $value);

value()

value 函数返回给定的值,然而,如果你传递一个闭包到该函数,该闭包将会被执行并返回执行结果:

$value = value(function() { return 'bar'; });

view()

view 函数获取一个视图实例:

return view('auth.login');

with()

with 函数返回给定的值,该函数在方法链中特别有用,别的地方就没什么用了:

$value = with(new Foo)->work();
 
标签: Laravel
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • nginx 各类网站设置 (laravel , thinkphp , nod
    基础部分设置[root@centos ~]# vim /opt/nginx/conf/nginx.confuser www www;worker_processes auto;pid logs/nginx.pid;worker_rlimit_nofile 100000;events {use epoll;multi_accept on;worker_connections 65535 ;}http {include mime.types;default_type
    02-09
  • PHP trait 特性在 Laravel 中的使用个人心得
    trait 是在PHP5.4中为了方便代码复用的一种实现方式,但目前我在看的的PHP项目中较少看的有程序员去主动使用这个实现方式,在laravel中有很多 trait 的使用,关于trait 在 laravel 的使用请参看 Laravel 在哪些地方用了 trait?我曾在 Laravel 中大型项目面向
    02-09
  • 让我们用 laravel-mix 为 TypeScript 和 Sass
    介绍前端编译TypeScript、Sass、模板引擎等时经常用到Gulp和webpack。这是我个人的印象,但它们似乎都难以管理,因为它们的描述往往复杂而冗长。我不想积极进行,因为我要担心加载器的顺序并且有很多配置选项,我必须花时间去了解它们。我想推荐那里laravel
  • PHP Laravel软删除的实现方法介绍
    用Laravel 自带的 Eloquent ORM 来实现软删除。首先在数据迁移文件中添加删除时间字段./database/migrations/2014_10_12_000000_create_users_table.php?phpuse Illuminate\Database\Migrations\Migration;use Illuminate\Database\Schema\Blueprint;use Illu
  • Laravel中如何使用PHP的装饰器模式 php laravel
    本文小编为大家详细介绍“Laravel中如何使用PHP的装饰器模式”,内容详细,步骤清晰,细节处理妥当,希望这篇“Laravel中如何使用PHP的装饰器模式”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。装饰器模式定义:它可以帮助您在
    02-08 laravelphp
  • PHP laravel使用自定义邮件类实现发送邮件
    PHP laravel使用自定义邮件类实现发送邮件
    当登录邮箱为腾讯企业邮箱的时候。Phpmailer发送邮件就不好用了,具体哪里不好用,我没真没找到。但是,邮件得发啊,怎么办呢?我这里搞了一个自定义的发送邮件类,腾讯企业邮箱也可用。但是,邮件发送失败,不会返回报错信息,这个可能是有点坑。源码如下:?
  • 详解PHP laravel中的加密与解密函数
    目录一:简介二:配置三:使用加密/解密1:加密2:不使用序列化进行加密3:解密Laravel为我们提供了完整的加密方法及加密模式。我之前一般在加密的时候使用的是我自己写的加密函数,但是这个玩意,有的位置还是不太使用,当然,破解的话,基本上也是不可能的
  • PHP laravel缓存cache机制详解
    目录一、访问多个缓存存储二、从缓存中获取数据1.获取数据并设置默认值2.检查缓存项是否存在3.数值增加/减少4.获取存储5.获取删除三、缓存中存储数据1.获取存储数据2.缓存不存在时存储数据3.永久存储数据四、从缓存中移除数据Laravel中的cache为我们提供了三
  • PHP laravel实现导出PDF功能
    PHP laravel实现导出PDF功能
    目录一、laravel-tcpdf二、tcpdf三、TCPDF解决保存中文文件名的方法补充一、laravel-tcpdf导出PDF文件Laravel框架为我们集成了一个插件tcpdf。下载地址:https://github.com/elibyy/tcpdf-laravel然后使用composer进行安装就可以了。具体安装过程,请查看文末
  • PHP laravel缓存cache机制怎么实现
    今天小编给大家分享一下PHP laravel缓存cache机制怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Laravel中的cache为我们
点击排行