简介

Laravel 包含各种各样的全局 PHP 「辅助」函数,框架本身也大量的使用了这些功能函数;如果你觉的方便,你可以在你的应用中任意使用这些函数。

可用方法

数组 & 对象

Arr::accessible
Arr::add
Arr::collapse
Arr::crossJoin
Arr::divide
Arr::dot
Arr::except
Arr::exists
Arr::first
Arr::flatten
Arr::forget
Arr::get
Arr::has
Arr::hasAny
Arr::isAssoc
Arr::isList
Arr::join
Arr::keyBy
Arr::last
Arr::map
Arr::only
Arr::pluck
Arr::prepend
Arr::prependKeysWith
Arr::pull
Arr::query
Arr::random
Arr::set
Arr::shuffle
Arr::sort
Arr::sortDesc
Arr::sortRecursive
Arr::toCssClasses
Arr::undot
Arr::where
Arr::whereNotNull
Arr::wrap
data_fill
data_get
data_set
head
last

路径

app_path
base_path
config_path
database_path
lang_path
mix
public_path
resource_path
storage_path

字符串

__
class_basename
e
preg_replace_array
Str::after
Str::afterLast
Str::ascii
Str::before
Str::beforeLast
Str::between
Str::betweenFirst
Str::camel
Str::contains
Str::containsAll
Str::endsWith
Str::excerpt
Str::finish
Str::headline
Str::inlineMarkdown
Str::is
Str::isAscii
Str::isJson
Str::isUlid
Str::isUuid
Str::kebab
Str::lcfirst
Str::length
Str::limit
Str::lower
Str::markdown
Str::mask
Str::orderedUuid
Str::padBoth
Str::padLeft
Str::padRight
Str::password
Str::plural
Str::pluralStudly
Str::random
Str::remove
Str::replace
Str::replaceArray
Str::replaceFirst
Str::replaceLast
Str::reverse
Str::singular
Str::slug
Str::snake
Str::squish
Str::start
Str::startsWith
Str::studly
Str::substr
Str::substrCount
Str::substrReplace
Str::swap
Str::title
Str::toHtmlString
Str::ucfirst
Str::ucsplit
Str::upper
Str::ulid
Str::uuid
Str::wordCount
Str::words
str
trans
trans_choice

字符流处理

after
afterLast
append
ascii
basename
before
beforeLast
between
betweenFirst
camel
classBasename
contains
containsAll
dirname
endsWith
excerpt
exactly
explode
finish
headline
inlineMarkdown
is
isAscii
isEmpty
isNotEmpty
isJson
isUlid
isUuid
kebab
lcfirst
length
limit
lower
ltrim
markdown
mask
match
matchAll
isMatch
newLine
padBoth
padLeft
padRight
pipe
plural
prepend
remove
replace
replaceArray
replaceFirst
replaceLast
replaceMatches
rtrim
scan
singular
slug
snake
split
squish
start
startsWith
studly
substr
substrReplace
swap
tap
test
title
trim
ucfirst
ucsplit
upper
when
whenContains
whenContainsAll
whenEmpty
whenNotEmpty
whenStartsWith
whenEndsWith
whenExactly
whenNotExactly
whenIs
whenIsAscii
whenIsUlid
whenIsUuid
whenTest
wordCount
words

URLs

action
asset
route
secure_asset
secure_url
to_route
url

杂项

abort
abort_if
abort_unless
app
auth
back
bcrypt
blank
broadcast
cache
class_uses_recursive
collect
config
cookie
csrf_field
csrf_token
decrypt
dd
dispatch
dump
encrypt
env
event
fake
filled
info
logger
method_field
now
old
optional
policy
redirect
report
report_if
report_unless
request
rescue
resolve
response
retry
session
tap
throw_if
throw_unless
today
trait_uses_recursive
transform
validator
value
view
with

方法列表

数组 & 对象

Arr::accessible() {.collection-method .first-collection-method}
php Arr::accessible 方法检查给定的值是否可被数组式访问:

  1. use Illuminate\Support\Arr;
  2. use Illuminate\Support\Collection;
  3. $isAccessible = Arr::accessible(['a' => 1, 'b' => 2]);
  4. // true
  5. $isAccessible = Arr::accessible(new Collection);
  6. // true
  7. $isAccessible = Arr::accessible('abc');
  8. // false
  9. $isAccessible = Arr::accessible(new stdClass);
  10. // false

Arr::add() {.collection-method}
如果给定的键名在数组中不存在键值或该键值设置为 php null ,那么 php Arr::add 方法将会把给定的键值对添加到数组中:

  1. use Illuminate\Support\Arr;
  2. $array = Arr::add(['name' => 'Desk'], 'price', 100);
  3. // ['name' => 'Desk', 'price' => 100]
  4. $array = Arr::add(['name' => 'Desk', 'price' => null], 'price', 100);
  5. // ['name' => 'Desk', 'price' => 100]

Arr::collapse() {.collection-method}
php Arr::collapse 方法将多个数组合并为一个数组:

  1. use Illuminate\Support\Arr;
  2. $array = Arr::collapse([[1, 2, 3], [4, 5, 6], [7, 8, 9]]);
  3. // [1, 2, 3, 4, 5, 6, 7, 8, 9]

Arr::crossJoin() {.collection-method}
php Arr::crossJoin 方法交叉连接给定的数组,返回具有所有可能排列的笛卡尔乘积:

  1. use Illuminate\Support\Arr;
  2. $matrix = Arr::crossJoin([1, 2], ['a', 'b']);
  3. /*
  4. [
  5. [1, 'a'],
  6. [1, 'b'],
  7. [2, 'a'],
  8. [2, 'b'],
  9. ]
  10. */
  11. $matrix = Arr::crossJoin([1, 2], ['a', 'b'], ['I', 'II']);
  12. /*
  13. [
  14. [1, 'a', 'I'],
  15. [1, 'a', 'II'],
  16. [1, 'b', 'I'],
  17. [1, 'b', 'II'],
  18. [2, 'a', 'I'],
  19. [2, 'a', 'II'],
  20. [2, 'b', 'I'],
  21. [2, 'b', 'II'],
  22. ]
  23. */

Arr::divide() {.collection-method}
php Arr::divide 方法返回一个二维数组,一个值包含原数组的键,另一个值包含原数组的值:

  1. use Illuminate\Support\Arr;
  2. [$keys, $values] = Arr::divide(['name' => 'Desk']);
  3. // $keys: ['name']
  4. // $values: ['Desk']

Arr::dot() {.collection-method}
php Arr::dot 方法将多维数组中所有的键平铺到一维数组中,新数组使用「.」符号表示层级包含关系:

  1. use Illuminate\Support\Arr;
  2. $array = ['products' => ['desk' => ['price' => 100]]];
  3. $flattened = Arr::dot($array);
  4. // ['products.desk.price' => 100]

Arr::except() {.collection-method}
php Arr::except 方法从数组中删除指定的键值对:

  1. use Illuminate\Support\Arr;
  2. $array = ['name' => 'Desk', 'price' => 100];
  3. $filtered = Arr::except($array, ['price']);
  4. // ['name' => 'Desk']

Arr::exists() {.collection-method}
php Arr::exists 方法检查给定的键是否存在提供的数组中:

  1. use Illuminate\Support\Arr;
  2. $array = ['name' => 'John Doe', 'age' => 17];
  3. $exists = Arr::exists($array, 'name');
  4. // true
  5. $exists = Arr::exists($array, 'salary');
  6. // false

Arr::first() {.collection-method}
php Arr::first 方法返回数组中满足指定条件的第一个元素:

  1. use Illuminate\Support\Arr;
  2. $array = [100, 200, 300];
  3. $first = Arr::first($array, function (int $value, int $key) {
  4. return $value >= 150;
  5. });
  6. // 200

可将默认值作为第三个参数传递给该方法,如果数组中没有值满足指定条件,则返回该默认值:

  1. use Illuminate\Support\Arr;
  2. $first = Arr::first($array, $callback, $default);

Arr::flatten() {.collection-method}
php Arr::flatten 方法将多维数组中数组的值取出平铺为一维数组:

  1. use Illuminate\Support\Arr;
  2. $array = ['name' => 'Joe', 'languages' => ['PHP', 'Ruby']];
  3. $flattened = Arr::flatten($array);
  4. // ['Joe', 'PHP', 'Ruby']

Arr::forget() {.collection-method}
php Arr::forget 方法使用「.」符号从深度嵌套的数组中删除给定的键值对:

  1. use Illuminate\Support\Arr;
  2. $array = ['products' => ['desk' => ['price' => 100]]];
  3. Arr::forget($array, 'products.desk');
  4. // ['products' => []]

Arr::get() {.collection-method}
php Arr::get 方法使用「.」符号从深度嵌套的数组中根据指定键检索值:

  1. use Illuminate\Support\Arr;
  2. $array = ['products' => ['desk' => ['price' => 100]]];
  3. $price = Arr::get($array, 'products.desk.price');
  4. // 100

php Arr::get 方法也可以接受一个默认值,如果数组中不存在指定的键,则返回默认值:

  1. use Illuminate\Support\Arr;
  2. $discount = Arr::get($array, 'products.desk.discount', 0);
  3. // 0

Arr::has() {.collection-method}
php Arr::has 方法使用「.」符号判断数组中是否存在指定的一个或多个键:

  1. use Illuminate\Support\Arr;
  2. $array = ['product' => ['name' => 'Desk', 'price' => 100]];
  3. $contains = Arr::has($array, 'product.name');
  4. // true
  5. $contains = Arr::has($array, ['product.price', 'product.discount']);
  6. // false

Arr::hasAny() {.collection-method}
php Arr::hasAny 方法使用「.」符号判断给定集合中的任一值是否存在于数组中:

  1. use Illuminate\Support\Arr;
  2. $array = ['product' => ['name' => 'Desk', 'price' => 100]];
  3. $contains = Arr::hasAny($array, 'product.name');
  4. // true
  5. $contains = Arr::hasAny($array, ['product.name', 'product.discount']);
  6. // true
  7. $contains = Arr::hasAny($array, ['category', 'product.discount']);
  8. // false

Arr::isAssoc() {.collection-method}
如果给定数组是关联数组,则 php Arr::isAssoc 方法返回 php true,如果该数组没有以零开头的顺序数字键,则将其视为「关联」数组:

  1. use Illuminate\Support\Arr;
  2. $isAssoc = Arr::isAssoc(['product' => ['name' => 'Desk', 'price' => 100]]);
  3. // true
  4. $isAssoc = Arr::isAssoc([1, 2, 3]);
  5. // false

Arr::isList() {.collection-method}
如果给定数组的键是从零开始的连续整数,则 php Arr::isList 方法返回 php true

  1. use Illuminate\Support\Arr;
  2. $isList = Arr::isList(['foo', 'bar', 'baz']);
  3. // true
  4. $isList = Arr::isList(['product' => ['name' => 'Desk', 'price' => 100]]);
  5. // false

Arr::join() {.collection-method}
php Arr::join()方法将给定数组的所有值通过给定字符串连接起来。使用此方法的第二个参数,您还可以为数组中的最后一个元素指定连接的字符串:

  1. use Illuminate\Support\Arr;
  2. $array = ['Tailwind', 'Alpine', 'Laravel', 'Livewire'];
  3. $joined = Arr::join($array, ', ');
  4. // Tailwind, Alpine, Laravel, Livewire
  5. $joined = Arr::join($array, ', ', ' and ');
  6. // Tailwind, Alpine, Laravel and Livewire

Arr::keyBy() {.collection-method}
php Arr::keyBy()方法通过给定键名的值对该数组进行重组。如果数组中存在多个相同的值,则只有最后一个值会出现在新数组中:

  1. use Illuminate\Support\Arr;
  2. $array = [
  3. ['product_id' => 'prod-100', 'name' => 'Desk'],
  4. ['product_id' => 'prod-200', 'name' => 'Chair'],
  5. ];
  6. $keyed = Arr::keyBy($array, 'product_id');
  7. /*
  8. [
  9. 'prod-100' => ['product_id' => 'prod-100', 'name' => 'Desk'],
  10. 'prod-200' => ['product_id' => 'prod-200', 'name' => 'Chair'],
  11. ]
  12. */

Arr::last() {.collection-method}
php Arr::last 方法返回数组中满足指定条件的最后一个元素:

  1. use Illuminate\Support\Arr;
  2. $array = [100, 200, 300, 110];
  3. $last = Arr::last($array, function (int $value, int $key) {
  4. return $value >= 150;
  5. });
  6. // 300

将默认值作为第三个参数传递给该方法,如果没有值满足条件,则返回该默认值:

  1. use Illuminate\Support\Arr;
  2. $last = Arr::last($array, $callback, $default);

Arr::map() {.collection-method}
php Arr::map 方法用来遍历数组,并将每个值和键传递给给定的回调。数组值由回调返回的值替换:

  1. use Illuminate\Support\Arr;
  2. $array = ['first' => 'james', 'last' => 'kirk'];
  3. $mapped = Arr::map($array, function (string $value, string $key) {
  4. return ucfirst($value);
  5. });
  6. // ['first' => 'James', 'last' => 'Kirk']

Arr::only() {.collection-method}
php Arr::only 方法仅返回给定数组中的指定键/值对:

  1. use Illuminate\Support\Arr;
  2. $array = ['name' => 'Desk', 'price' => 100, 'orders' => 10];
  3. $slice = Arr::only($array, ['name', 'price']);
  4. // ['name' => 'Desk', 'price' => 100]

Arr::pluck() {.collection-method}
php Arr::pluck 方法从数组中检索给定键的所有值:

  1. use Illuminate\Support\Arr;
  2. $array = [
  3. ['developer' => ['id' => 1, 'name' => 'Taylor']],
  4. ['developer' => ['id' => 2, 'name' => 'Abigail']],
  5. ];
  6. $names = Arr::pluck($array, 'developer.name');
  7. // ['Taylor', 'Abigail']

你也可以指定结果的键:

  1. use Illuminate\Support\Arr;
  2. $names = Arr::pluck($array, 'developer.name', 'developer.id');
  3. // [1 => 'Taylor', 2 => 'Abigail']

Arr::last() {.collection-method}
php Arr::last 方法返回数组中满足指定条件的最后一个元素:

  1. use Illuminate\Support\Arr;
  2. $array = [100, 200, 300, 110];
  3. $last = Arr::last($array, function (int $value, int $key) {
  4. return $value >= 150;
  5. });
  6. // 300

将默认值作为第三个参数传递给该方法,如果没有值满足指定条件,则返回该默认值:

  1. use Illuminate\Support\Arr;
  2. $last = Arr::last($array, $callback, $default);

Arr::map() {.collection-method}
php Arr::map 方法遍历数组并将每个键和值传递至给定的回调方法。数组的值将替换为该回调方法返回的值:

  1. use Illuminate\Support\Arr;
  2. $array = ['first' => 'james', 'last' => 'kirk'];
  3. $mapped = Arr::map($array, function (string $value, string $key) {
  4. return ucfirst($value);
  5. });
  6. // ['first' => 'James', 'last' => 'Kirk']

Arr::only() {.collection-method}
php Arr::only 方法只返回给定数组中指定的键值对:

  1. use Illuminate\Support\Arr;
  2. $array = ['name' => 'Desk', 'price' => 100, 'orders' => 10];
  3. $slice = Arr::only($array, ['name', 'price']);
  4. // ['name' => 'Desk', 'price' => 100]

Arr::pluck() {.collection-method}
php Arr::pluck 方法从数组中检索给定键的所有值:

  1. use Illuminate\Support\Arr;
  2. $array = [
  3. ['developer' => ['id' => 1, 'name' => 'Taylor']],
  4. ['developer' => ['id' => 2, 'name' => 'Abigail']],
  5. ];
  6. $names = Arr::pluck($array, 'developer.name');
  7. // ['Taylor', 'Abigail']

你还可以指定结果的键:

  1. use Illuminate\Support\Arr;
  2. $names = Arr::pluck($array, 'developer.name', 'developer.id');
  3. // [1 => 'Taylor', 2 => 'Abigail']

Arr::prepend() {.collection-method}
php Arr::prepend 方法将一个值插入到数组的开始位置:

  1. use Illuminate\Support\Arr;
  2. $array = ['one', 'two', 'three', 'four'];
  3. $array = Arr::prepend($array, 'zero');
  4. // ['zero', 'one', 'two', 'three', 'four']

你也可以指定插入值的键:

  1. use Illuminate\Support\Arr;
  2. $array = ['price' => 100];
  3. $array = Arr::prepend($array, 'Desk', 'name');
  4. // ['name' => 'Desk', 'price' => 100]

Arr::prependKeysWith() {.collection-method}
php Arr::prependKeysWith 方法为关联数组中的所有键添加给定前缀:

  1. use Illuminate\Support\Arr;
  2. $array = [
  3. 'name' => 'Desk',
  4. 'price' => 100,
  5. ];
  6. $keyed = Arr::prependKeysWith($array, 'product.');
  7. /*
  8. [
  9. 'product.name' => 'Desk',
  10. 'product.price' => 100,
  11. ]
  12. */

Arr::pull() {.collection-method}
php Arr::pull 方法从数组中返回指定键的值并删除此键值对:

  1. use Illuminate\Support\Arr;
  2. $array = ['name' => 'Desk', 'price' => 100];
  3. $name = Arr::pull($array, 'name');
  4. // $name: Desk
  5. // $array: ['price' => 100]

默认值可以作为第三个参数传递给该方法。如果指定键不存在,则返回该值:

  1. use Illuminate\Support\Arr;
  2. $value = Arr::pull($array, $key, $default);

Arr::query() {.collection-method}
php Arr::query 方法将数组转换为查询字符串:

  1. use Illuminate\Support\Arr;
  2. $array = [
  3. 'name' => 'Taylor',
  4. 'order' => [
  5. 'column' => 'created_at',
  6. 'direction' => 'desc'
  7. ]
  8. ];
  9. Arr::query($array);
  10. // name=Taylor&order[column]=created_at&order[direction]=desc

Arr::random() {.collection-method}
php Arr::random 方法从数组中随机返回一个值:

  1. use Illuminate\Support\Arr;
  2. $array = [1, 2, 3, 4, 5];
  3. $random = Arr::random($array);
  4. // 4 - (retrieved randomly)

你还可以指定返回值的数量作为可选的第二个参数传递给该方法,请注意,提供这个参数会返回一个数组,即使是你只需要一项:

  1. use Illuminate\Support\Arr;
  2. $items = Arr::random($array, 2);
  3. // [2, 5] - (retrieved randomly)

Arr::set() {.collection-method}
php Arr::set 方法使用「.」符号在多维数组中设置指定键的值:

  1. use Illuminate\Support\Arr;
  2. $array = ['products' => ['desk' => ['price' => 100]]];
  3. Arr::set($array, 'products.desk.price', 200);
  4. // ['products' => ['desk' => ['price' => 200]]]

Arr::shuffle() {.collection-method}
php Arr::shuffle 方法将数组中值进行随机排序:

  1. use Illuminate\Support\Arr;
  2. $array = Arr::shuffle([1, 2, 3, 4, 5]);
  3. // [3, 2, 5, 1, 4] - (generated randomly)

Arr::sort() {.collection-method}
php Arr::sort 方法根据给定数组的值进行升序排序:

  1. use Illuminate\Support\Arr;
  2. $array = ['Desk', 'Table', 'Chair'];
  3. $sorted = Arr::sort($array);
  4. // ['Chair', 'Desk', 'Table']

你还可以根据给定回调方法的返回结果对数组进行排序:

  1. use Illuminate\Support\Arr;
  2. $array = [
  3. ['name' => 'Desk'],
  4. ['name' => 'Table'],
  5. ['name' => 'Chair'],
  6. ];
  7. $sorted = array_values(Arr::sort($array, function (array $value) {
  8. return $value['name'];
  9. }));
  10. /*
  11. [
  12. ['name' => 'Chair'],
  13. ['name' => 'Desk'],
  14. ['name' => 'Table'],
  15. ]
  16. */

Arr::sortDesc() {.collection-method}
php Arr::sortDesc 方法根据给定数组的值进行降序排序:

  1. use Illuminate\Support\Arr;
  2. $array = ['Desk', 'Table', 'Chair'];
  3. $sorted = Arr::sortDesc($array);
  4. // ['Table', 'Desk', 'Chair']

你还可以根据给定回调方法的返回结果对数组进行排序:

  1. use Illuminate\Support\Arr;
  2. $array = [
  3. ['name' => 'Desk'],
  4. ['name' => 'Table'],
  5. ['name' => 'Chair'],
  6. ];
  7. $sorted = array_values(Arr::sortDesc($array, function (array $value) {
  8. return $value['name'];
  9. }));
  10. /*
  11. [
  12. ['name' => 'Table'],
  13. ['name' => 'Desk'],
  14. ['name' => 'Chair'],
  15. ]
  16. */

Arr::sortRecursive() {.collection-method}
php Arr::sortRecursive 方法对给定数组进行递归排序,使用 php sort 方法对数字索引子数组进行按值升序排序,使用 php ksort 方法对关联子数组进行按键升序排序:

  1. use Illuminate\Support\Arr;
  2. $array = [
  3. ['Roman', 'Taylor', 'Li'],
  4. ['PHP', 'Ruby', 'JavaScript'],
  5. ['one' => 1, 'two' => 2, 'three' => 3],
  6. ];
  7. $sorted = Arr::sortRecursive($array);
  8. /*
  9. [
  10. ['JavaScript', 'PHP', 'Ruby'],
  11. ['one' => 1, 'three' => 3, 'two' => 2],
  12. ['Li', 'Roman', 'Taylor'],
  13. ]
  14. */

Arr::toCssClasses() {.collection-method}
php Arr::toCssClasses 方法根据给定的条件编译并返回 CSS 类字符串。该方法接受一个类数组,其中数组键包含你希望添加的一个或多个 CSS Class,而值是一个布尔表达式。如果数组元素有一个数字键,它将始终包含在呈现的类列表中:

  1. use Illuminate\Support\Arr;
  2. $isActive = false;
  3. $hasError = true;
  4. $array = ['p-4', 'font-bold' => $isActive, 'bg-red' => $hasError];
  5. $classes = Arr::toCssClasses($array);
  6. /*
  7. 'p-4 bg-red'
  8. */

Laravel 基于该方法实现 Blade 组件里的条件合并类 以及 php @class Blade 指令:

Arr::undot() {.collection-method}
php Arr::undot 方法使用「.」符号将一维数组扩展为多维数组:

  1. use Illuminate\Support\Arr;
  2. $array = [
  3. 'user.name' => 'Kevin Malone',
  4. 'user.occupation' => 'Accountant',
  5. ];
  6. $array = Arr::undot($array);
  7. // ['user' => ['name' => 'Kevin Malone', 'occupation' => 'Accountant']]

Arr::where() {.collection-method}
php Arr::where 方法使用给定的回调函数返回的结果过滤数组:

  1. use Illuminate\Support\Arr;
  2. $array = [100, '200', 300, '400', 500];
  3. $filtered = Arr::where($array, function (string|int $value, int $key) {
  4. return is_string($value);
  5. });
  6. // [1 => '200', 3 => '400']

Arr::whereNotNull() {.collection-method}
php Arr::whereNotNull 方法将从给定数组中删除所有 php null 值:

  1. use Illuminate\Support\Arr;
  2. $array = [0, null];
  3. $filtered = Arr::whereNotNull($array);
  4. // [0 => 0]

Arr::wrap() {.collection-method}
php Arr::wrap 方法可以将给定值转换为一个数组,如果给定的值已经是一个数组,它将原样返回:

  1. use Illuminate\Support\Arr;
  2. $string = 'Laravel';
  3. $array = Arr::wrap($string);
  4. // ['Laravel']

如果给定值是 php null ,将返回一个空数组:

  1. use Illuminate\Support\Arr;
  2. $array = Arr::wrap(null);
  3. // []

data_fill() {#collection-method}
php data_fill 函数使用「.」符号给多维数组或对象设置缺少的值:

  1. $data = ['products' => ['desk' => ['price' => 100]]];
  2. data_fill($data, 'products.desk.price', 200);
  3. // ['products' => ['desk' => ['price' => 100]]]
  4. data_fill($data, 'products.desk.discount', 10);
  5. // ['products' => ['desk' => ['price' => 100, 'discount' => 10]]]

也可以接收 「*」 作为通配符,设置相应缺少的值:

  1. $data = [
  2. 'products' => [
  3. ['name' => 'Desk 1', 'price' => 100],
  4. ['name' => 'Desk 2'],
  5. ],
  6. ];
  7. data_fill($data, 'products.*.price', 200);
  8. /*
  9. [
  10. 'products' => [
  11. ['name' => 'Desk 1', 'price' => 100],
  12. ['name' => 'Desk 2', 'price' => 200],
  13. ],
  14. ]
  15. */

data_get() {#collection-method}
php data_get 函数使用 「.」 符号从多维数组或对象中根据指定键检索值

  1. $data = ['products' => ['desk' => ['price' => 100]]];
  2. $price = data_get($data, 'products.desk.price');
  3. // 100

php data_get 函数也接受一个默认值,如果没有找到指定的键,将返回默认值:

  1. $discount = data_get($data, 'products.desk.discount', 0);
  2. // 0

该函数还接受「*」作为通配符,来指向数组或对象的任何键:

  1. $data = [
  2. 'product-one' => ['name' => 'Desk 1', 'price' => 100],
  3. 'product-two' => ['name' => 'Desk 2', 'price' => 150],
  4. ];
  5. data_get($data, '*.name');
  6. // ['Desk 1', 'Desk 2'];

data_set() {#collection-method}
php data_set 函数使用「.」符号从多维数组或对象中根据指定键设置值:

  1. $data = ['products' => ['desk' => ['price' => 100]]];
  2. data_set($data, 'products.desk.price', 200);
  3. // ['products' => ['desk' => ['price' => 200]]]

php data_get 一样,函数也支持使用「*」 作为通配符给相应键名赋值:

  1. $data = [
  2. 'products' => [
  3. ['name' => 'Desk 1', 'price' => 100],
  4. ['name' => 'Desk 2', 'price' => 150],
  5. ],
  6. ];
  7. data_set($data, 'products.*.price', 200);
  8. /*
  9. [
  10. 'products' => [
  11. ['name' => 'Desk 1', 'price' => 200],
  12. ['name' => 'Desk 2', 'price' => 200],
  13. ],
  14. ]
  15. */

通常情况下,已存在的值将会被覆盖。如果只是希望设置一个目前不存在的值,你可以增加一个 php false 作为函数的第四个参数:

  1. $data = ['products' => ['desk' => ['price' => 100]]];
  2. data_set($data, 'products.desk.price', 200, overwrite: false);
  3. // ['products' => ['desk' => ['price' => 100]]]

head() {#collection-method}
php head 函数将返回数组中的第一个值:

  1. $array = [100, 200, 300];
  2. $first = head($array);
  3. // 100

last() {.collection-method}
php last 函数将返回数组中的最后一个值:

  1. $array = [100, 200, 300];
  2. $last = last($array);
  3. // 300

路径

app_path() {.collection-method}
php app_path 函数返回 php app 目录的完整路径。你也可以使用 php app_path 函数来生成应用目录下特定文件的完整路径:

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

base_path() {#collection-method}
php base_path 函数返回项目根目录的完整路径。你也可以使用 php base_path 函数生成项目根目录下特定文件的完整路径:

  1. $path = base_path();
  2. $path = base_path('vendor/bin');

config_path() {#collection-method}
php config_path 函数返回项目配置目录 (config) 的完整路径。你也可以使用 php config_path 函数来生成应用配置目录中的特定文件的完整路径:

  1. $path = config_path();
  2. $path = config_path('app.php');

database_path() {.collection-method}
php database_path 函数返回 php database 目录的完整路径。你可以使用 php database_path 函数来生成数据库目录下指定文件的完整路径:

  1. $path = database_path();
  2. $path = database_path('factories/UserFactory.php');

lang_path() {.collection-method}
The php lang_path 函数返回 php lang 目录的完整路径。你可以使用 php lang_path 函数来生成自定义语言目录下指定文件的完整路径:

  1. $path = lang_path();
  2. $path = lang_path('en/messages.php');

注意
默认情况下,Laravel 框架不包含 php lang 目录。如果你想自定义 Laravel 的语言文件,可以通过 Artisan 命令 php lang:publish 来发布它们。

mix() {.collection-method}
php mix 函数返回 编译前端资源(Mix)的路径,便于加载 css,js 等静态文件:

  1. $path = mix('css/app.css');

public_path() {.collection-method}
php public_path 函数返回 php public 目录的完整路径。你可以使用 php public_path 函数来生成php public 目录下指定文件的完整路径:

  1. $path = public_path();
  2. $path = public_path('css/app.css');

resource_path() {.collection-method}
php resource_path 函数返回 php resource 目录的完整路径。你可以使用 php resource_path 函数来生成位于资源路径中指定文件的完整路径:

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

storage_path()
php storage_path 函数返回 php storage 目录的完整路径。 你也可以用 php storage_path 函数来生成位于资源路径中的特定文件路径

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

字符串

()
```php
```函数可使用 本地化文件 来翻译指定的字符串或特定的 key

  1. echo __('Welcome to our application');
  2. echo __('messages.welcome');

如果给定翻译的字符串或者 key 不存在, 则 php __ 会返回你指定的值。所以上述例子中, 如果给定翻译的字符串或者 key 不存在,则 php __ 函数会返回 php messages.welcome

class_basename()
php class_basename 函数返回不带命名空间的特定类的类名:

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

e()
php e 函数运行 PHP 的 php htmlspecialchars 函数,且 php double_encode 默认设定为 php true

  1. echo e('<html>foo</html>');
  2. // &lt;html&gt;foo&lt;/html&gt;

preg_replace_array() {.collection-method}
php preg_replace_array 函数按数组顺序替换字符串中符合给定模式的字符:

  1. $string = 'The event will take place between :start and :end';
  2. $replaced = preg_replace_array('/:[a-z_]+/', ['8:30', '9:00'], $string);
  3. // The event will take place between 8:30 and 9:00

Str::after()
php Str::after 方法返回字符串中指定值之后的所有内容。如果字符串中不存在这个值,它将返回整个字符串:

  1. use Illuminate\Support\Str;
  2. $slice = Str::after('This is my name', 'This is');
  3. // ' my name'

Str::afterLast()
php Str::afterLast 方法返回字符串中指定值最后一次出现后的所有内容。如果字符串中不存在这个值,它将返回整个字符串:

  1. use Illuminate\Support\Str;
  2. $slice = Str::afterLast('App\Http\Controllers\Controller', '\\');
  3. // 'Controller'

Str::ascii()
php Str::ascii 方法尝试将字符串转换为 ASCII 值:

  1. use Illuminate\Support\Str;
  2. $slice = Str::ascii('û');
  3. // 'u'

Str::before()
php Str::before 方法返回字符串中指定值之前的所有内容:

  1. use Illuminate\Support\Str;
  2. $slice = Str::before('This is my name', 'my name');
  3. // 'This is '

Str::beforeLast()
php Str::beforeLast 方法返回字符串中指定值最后一次出现前的所有内容:

  1. use Illuminate\Support\Str;
  2. $slice = Str::beforeLast('This is my name', 'is');
  3. // 'This '

Str::between()
php Str::between 方法返回字符串在指定两个值之间的内容:

  1. use Illuminate\Support\Str;
  2. $slice = Str::between('This is my name', 'This', 'name');
  3. // ' is my '

Str::betweenFirst()
php Str::betweenFirst 方法返回字符串在指定两个值之间的最小可能的部分:

  1. use Illuminate\Support\Str;
  2. $slice = Str::betweenFirst('[a] bc [d]', '[', ']');
  3. // 'a'

Str::camel()
php Str::camel 方法将指定字符串转换为 php 驼峰式 表示方法:

  1. use Illuminate\Support\Str;
  2. $converted = Str::camel('foo_bar');
  3. // fooBar

Str::contains()
php Str::contains 方法判断指定字符串中是否包含另一指定字符串(区分大小写):

  1. use Illuminate\Support\Str;
  2. $contains = Str::contains('This is my name', 'my');
  3. // true

你也可以传递一个数组来判断指定字符串是否包含数组中的任一值:

  1. use Illuminate\Support\Str;
  2. $contains = Str::contains('This is my name', ['my', 'foo']);
  3. // true

Str::containsAll()
php Str::containsAll 方法用于判断指定字符串是否包含指定数组中的所有值:

  1. use Illuminate\Support\Str;
  2. $containsAll = Str::containsAll('This is my name', ['my', 'name']);
  3. // true

Str::endsWith()
php Str::endsWith 方法用于判断指定字符串是否以另一指定字符串结尾:

  1. use Illuminate\Support\Str;
  2. $result = Str::endsWith('This is my name', 'name');
  3. // true

你也可以传一个数组来判断指定字符串是否以指定数组中的任一值结尾:

  1. use Illuminate\Support\Str;
  2. $result = Str::endsWith('This is my name', ['name', 'foo']);
  3. // true
  4. $result = Str::endsWith('This is my name', ['this', 'foo']);
  5. // false

Str::excerpt()
php Str::excerpt 方法提取字符串中给定短语匹配到的第一个片段:

  1. use Illuminate\Support\Str;
  2. $excerpt = Str::excerpt('This is my name', 'my', [
  3. 'radius' => 3
  4. ]);
  5. // '...is my na...'

php radius 选项默认为 php 100,允许你定义应出现在截断字符串前后的字符数。

此外,你可以使用php omission选项来定义将附加到截断字符串的字符串:

  1. use Illuminate\Support\Str;
  2. $excerpt = Str::excerpt('This is my name', 'name', [
  3. 'radius' => 3,
  4. 'omission' => '(...) '
  5. ]);
  6. // '(...) my name'

Str::finish() {.collection-method}
php Str::finish方法将指定的字符串修改为以指定的值结尾的形式:

  1. use Illuminate\Support\Str;
  2. $adjusted = Str::finish('this/string', '/');
  3. // this/string/
  4. $adjusted = Str::finish('this/string/', '/');
  5. // this/string/

Str::headline() {.collection-method}
php Str::headline方法会将由大小写、连字符或下划线分隔的字符串转换为空格分隔的字符串,同时保证每个单词的首字母大写:

  1. use Illuminate\Support\Str;
  2. $headline = Str::headline('steve_jobs');
  3. // Steve Jobs
  4. $headline = Str::headline('邮件通知发送');
  5. // 邮件通知发送

Str::inlineMarkdown() {.collection-method}
php Str::inlineMarkdown方法使用 通用标记将 GitHub 风味 Markdown 转换为内联 HTML。然而,与php markdown方法不同的是,它不会将所有生成的 HTML 都包装在块级元素中:

  1. use Illuminate\Support\Str;
  2. $html = Str::inlineMarkdown('**Laravel**');
  3. // <strong>Laravel</strong>

Str::is() {.collection-method}
php Str::is方法用来判断字符串是否与指定模式匹配。星号php *可用于表示通配符:

  1. use Illuminate\Support\Str;
  2. $matches = Str::is('foo*', 'foobar');
  3. // true
  4. $matches = Str::is('baz*', 'foobar');
  5. // false

Str::isAscii() {.collection-method}
php Str::isAscii方法用于判断字符串是否是 7 位 ASCII:

  1. use Illuminate\Support\Str;
  2. $isAscii = Str::isAscii('Taylor');
  3. // true
  4. $isAscii = Str::isAscii('ü');
  5. // false

Str::isJson() {.collection-method}
php Str::isJson方法确定给定的字符串是否是有效的 JSON:

  1. use Illuminate\Support\Str;
  2. $result = Str::isJson('[1,2,3]');
  3. // true
  4. $result = Str::isJson('{"first": "John", "last": "Doe"}');
  5. // true
  6. $result = Str::isJson('{first: "John", last: "Doe"}');
  7. // false

Str::isUlid() {.collection-method}
php Str::isUlid方法用于判断指定字符串是否是有效的 ULID:

  1. use Illuminate\Support\Str;
  2. $isUlid = Str::isUlid('01gd6r360bp37zj17nxb55yv40');
  3. // true
  4. $isUlid = Str::isUlid('laravel');
  5. // false

Str::isUuid() {.collection-method}
php Str::isUuid方法用于判断指定字符串是否是有效的 UUID:

  1. use Illuminate\Support\Str;
  2. $isUuid = Str::isUuid('a0a2a2d2-0b87-4a18-83f2-2529882be2de');
  3. // true
  4. $isUuid = Str::isUuid('laravel');
  5. // false

Str::kebab() {.collection-method}
php Str::kebab方法将字符串转换为php 烤串式( kebab-case )表示方法:

  1. use Illuminate\Support\Str;
  2. $converted = Str::kebab('fooBar');
  3. // foo-bar

Str::lcfirst() {.collection-method}
php Str::lcfirst方法返回第一个小写字符的给定字符串:

  1. use Illuminate\Support\Str;
  2. $string = Str::lcfirst('Foo Bar');
  3. // foo Bar

Str::length() {.collection-method}
php Str::length方法返回指定字符串的长度:

  1. use Illuminate\Support\Str;
  2. $length = Str::length('Laravel');
  3. // 7

Str::limit() {.collection-method}
php Str::limit方法将字符串以指定长度进行截断:

  1. use Illuminate\Support\Str;
  2. $truncated = Str::limit('敏捷的棕色狐狸跳过懒惰的狗', 20);
  3. // 敏捷的棕色狐狸...

你也可通过第三个参数来改变追加到末尾的字符串:

  1. use Illuminate\Support\Str;
  2. $truncated = Str::limit('敏捷的棕色狐狸跳过懒惰的狗', 20, ' (...)');
  3. // 敏捷的棕色狐狸 (...)

Str::lower() {.collection-method}
php Str::lower方法用于将字符串转换为小写:

  1. use Illuminate\Support\Str;
  2. $converted = Str::lower('LARAVEL');
  3. // laravel

Str::markdown() {.collection-method}
php Str::markdown方法将 GitHub 风格的 Markdown 转换为 HTML 使用 通用标记:

  1. use Illuminate\Support\Str;
  2. $html = Str::markdown('# Laravel');
  3. // <h1>Laravel</h1>
  4. $html = Str::markdown('# Taylor <b>Otwell</b>', [
  5. 'html_input' => 'strip',
  6. ]);
  7. // <h1>Taylor Otwell</h1>

Str::mask() {.collection-method}
php Str::mask方法会使用重复的字符掩盖字符串的一部分,并可用于混淆字符串段,例如电子邮件地址和电话号码:

  1. use Illuminate\Support\Str;
  2. $string = Str::mask('taylor@example.com', '*', 3);
  3. // tay***************

你可以提供一个负数作为php mask方法的第三个参数,这将指示该方法在距字符串末尾的给定距离处开始屏蔽:

  1. $string = Str::mask('taylor@example.com', '*', -15, 3);
  2. // tay***@example.com

Str::orderedUuid() {.collection-method}
php Str::orderedUuid方法用于生成一个「时间戳优先」的 UUID ,它可作为数据库索引列的有效值。使用此方法生成的每个 UUID 将排在之前使用该方法生成的 UUID 后面:

  1. use Illuminate\Support\Str;
  2. return (string) Str::orderedUuid();

Str::padBoth() {.collection-method}
php Str::padBoth方法包装了 PHP 的php str_pad 方法,在指定字符串的两侧填充上另一字符串:

  1. use Illuminate\Support\Str;
  2. $padded = Str::padBoth('James', 10, '_');
  3. // '__James___'
  4. $padded = Str::padBoth('James', 10);
  5. // ' James '

Str::padLeft() {.collection-method}
php Str::padLeft方法包装了 PHP 的php str_pad方法,在指定字符串的左侧填充上另一字符串:

  1. use Illuminate\Support\Str;
  2. $padded = Str::padLeft('James', 10, '-=');
  3. // '-=-=-James'
  4. $padded = Str::padLeft('James', 10);
  5. // ' James'

Str::padRight() {.collection-method}
php Str::padRight方法包装了 PHP 的php str_pad方法,在指定字符串的右侧填充上另一字符串:

  1. use Illuminate\Support\Str;
  2. $padded = Str::padRight('James', 10, '-');
  3. // 'James-----'
  4. $padded = Str::padRight('James', 10);
  5. // 'James '

Str::password() {.collection-method}
php Str::password方法可用于生成给定长度的安全随机密码。密码由字母、数字、符号和空格组成。默认情况下,密码长度为32位:

  1. use Illuminate\Support\Str;
  2. $password = Str::password();
  3. // 'EbJo2vE-AS:U,$%_gkrV4n,q~1xy/-_4'
  4. $password = Str::password(12);
  5. // 'qwuar>#V|i]N'

Str::plural() {.collection-method}
php Str::plural方法将单数形式的字符串转换为复数形式。此方法支持 Laravel 复数形式所支持的任何语言:

  1. use Illuminate\Support\Str;
  2. $plural = Str::plural('car');
  3. // cars
  4. $plural = Str::plural('child');
  5. // children

你可以提供一个整数作为方法的第二个参数来检索字符串的单数或复数形式:

  1. use Illuminate\Support\Str;
  2. $plural = Str::plural('child', 2);
  3. // children
  4. $singular = Str::plural('child', 1);
  5. // child

Str::pluralStudly() {.collection-method}
php Str::pluralStudly方法将以驼峰格式的单数字符串转化为其复数形式。此方法支持 Laravel 复数形式所支持的任何语言:

  1. use Illuminate\Support\Str;
  2. $plural = Str::pluralStudly('VerifiedHuman');
  3. // VerifiedHumans
  4. $plural = Str::pluralStudly('UserFeedback');
  5. // UserFeedback

你可以提供一个整数作为方法的第二个参数来检索字符串的单数或复数形式:

  1. use Illuminate\Support\Str;
  2. $plural = Str::pluralStudly('VerifiedHuman', 2);
  3. // VerifiedHumans
  4. $singular = Str::pluralStudly('VerifiedHuman', 1);
  5. // VerifiedHuman

Str::random() {.collection-method}
php Str::random 方法用于生成指定长度的随机字符串。这个方法使用了PHP的 php random_bytes 函数:

  1. use Illuminate\Support\Str;
  2. $random = Str::random(40);

Str::remove() {.collection-method}
php Str::remove 方法从字符串中删除给定值或给定数组内的所有值:

  1. use Illuminate\Support\Str;
  2. $string = 'Peter Piper picked a peck of pickled peppers.';
  3. $removed = Str::remove('e', $string);
  4. // Ptr Pipr pickd a pck of pickld ppprs.

你还可以将php false作为第三个参数传递给php remove方法以在删除字符串时忽略大小写。

Str::replace() {.collection-method}
php Str::replace 方法用于替换字符串中的给定字符串:

  1. use Illuminate\Support\Str;
  2. $string = 'Laravel 10.x';
  3. $replaced = Str::replace('9.x', '10.x', $string);
  4. // Laravel 10.x

Str::replaceArray() {.collection-method}
php Str::replaceArray 方法使用数组有序的替换字符串中的特定字符:

  1. use Illuminate\Support\Str;
  2. $string = '该活动将在 ? 至 ? 举行';
  3. $replaced = Str::replaceArray('?', ['8:30', '9:00'], $string);
  4. // 该活动将在 8:30 至 9:00 举行

Str::replaceFirst() {.collection-method}
php Str::replaceFirst 方法替换字符串中给定值的第一个匹配项:

  1. use Illuminate\Support\Str;
  2. $replaced = Str::replaceFirst('the', 'a', 'the quick brown fox jumps over the lazy dog');
  3. // a quick brown fox jumps over the lazy dog

Str::replaceLast() {.collection-method}
php Str::replaceLast 方法替换字符串中最后一次出现的给定值:

  1. use Illuminate\Support\Str;
  2. $replaced = Str::replaceLast('the', 'a', 'the quick brown fox jumps over the lazy dog');
  3. // the quick brown fox jumps over a lazy dog

Str::reverse() {.collection-method}
php Str::reverse 方法用于反转给定的字符串:

  1. use Illuminate\Support\Str;
  2. $reversed = Str::reverse('Hello World');
  3. // dlroW olleH

Str::singular() {.collection-method}
php Str::singular 方法将字符串转换为单数形式。此方法支持 Laravel 复数形式所支持的任何语言:

  1. use Illuminate\Support\Str;
  2. $singular = Str::singular('cars');
  3. // car
  4. $singular = Str::singular('children');
  5. // child

Str::slug() {.collection-method}
php Str::slug 方法将给定的字符串生成一个 URL 友好的「slug」:

  1. use Illuminate\Support\Str;
  2. $slug = Str::slug('Laravel 10 Framework', '-');
  3. // laravel-10-framework

Str::snake() {.collection-method}
php Str::snake 方法是将驼峰的函数名或者字符串转换成 php _ 命名的函数或者字符串,例如 php snakeCase 转换成 php snake_case

  1. use Illuminate\Support\Str;
  2. $converted = Str::snake('fooBar');
  3. // foo_bar
  4. $converted = Str::snake('fooBar', '-');
  5. // foo-bar

Str::squish() {.collection-method}
php Str::squish方法删除字符串中所有多余的空白,包括单词之间多余的空白:

  1. use Illuminate\Support\Str;
  2. $string = Str::squish(' laravel framework ');
  3. // laravel framework

Str::start() {.collection-method}
php Str::start方法是将给定的值添加到字符串的开始位置,例如:

  1. use Illuminate\Support\Str;
  2. $adjusted = Str::start('this/string', '/');
  3. // /this/string
  4. $adjusted = Str::start('/this/string', '/');
  5. // /this/string

Str::startsWith() {.collection-method}
php Str::startsWith方法用来判断给定的字符串是否为给定值的开头:

  1. use Illuminate\Support\Str;
  2. $result = Str::startsWith('This is my name', 'This');
  3. // true

如果传递了一个可能值的数组且字符串以任何给定值开头,则php startsWith方法将返回php true

  1. $result = Str::startsWith('This is my name', ['This', 'That', 'There']);
  2. // true

Str::studly() {.collection-method}
php Str::studly方法将给定的字符串转换为php 驼峰命名的字符串:

  1. use Illuminate\Support\Str;
  2. $converted = Str::studly('foo_bar');
  3. // FooBar

Str::substr() {.collection-method}
php Str::substr方法返回由 start 和 length 参数指定的字符串部分:

  1. use Illuminate\Support\Str;
  2. $converted = Str::substr('The Laravel Framework', 4, 7);
  3. // Laravel

Str::substrCount() {.collection-method}
php Str::substrCount 方法返回给定字符串中给定值的出现次数:

  1. use Illuminate\Support\Str;
  2. $count = Str::substrCount('If you like ice cream, you will like snow cones.', 'like');
  3. // 2

Str::substrReplace() {.collection-method}
php Str::substrReplace 方法替换字符串一部分中的文本,从第三个参数指定的位置开始,替换第四个参数指定的字符数。 当「0」传递给方法的第四个参数将在指定位置插入字符串,而不是替换字符串中的任何现有字符:

  1. use Illuminate\Support\Str;
  2. $result = Str::substrReplace('1300', ':', 2);
  3. // 13:
  4. $result = Str::substrReplace('1300', ':', 2, 0);
  5. // 13:00

Str::swap() {.collection-method}
php Str::swap 方法使用 PHP 的 php strtr 函数替换给定字符串中的多个值:

  1. use Illuminate\Support\Str;
  2. $string = Str::swap([
  3. 'Tacos' => 'Burritos',
  4. 'great' => 'fantastic',
  5. ], 'Tacos are great!');
  6. // Burritos are fantastic!

Str::title() {.collection-method}
php Str::title 方法将给定的字符串转换为 php Title Case

  1. use Illuminate\Support\Str;
  2. $converted = Str::title('a nice title uses the correct case');
  3. // A Nice Title Uses The Correct Case

Str::toHtmlString() {.collection-method}
php Str::toHtmlString 方法将字符串实例转换为 php Illuminate\Support\HtmlString 的实例,它可以显示在 Blade 模板中:

  1. use Illuminate\Support\Str;
  2. $htmlString = Str::of('Nuno Maduro')->toHtmlString();

Str::ucfirst() {.collection-method}
php Str::ucfirst 方法返回第一个字符大写的给定字符串:

  1. use Illuminate\Support\Str;
  2. $string = Str::ucfirst('foo bar');
  3. // Foo bar

Str::ucsplit() {.collection-method}
php Str::ucsplit 方法将给定的字符串按大写字符拆分为数组:

  1. use Illuminate\Support\Str;
  2. $segments = Str::ucsplit('FooBar');
  3. // [0 => 'Foo', 1 => 'Bar']

Str::upper() {.collection-method}
php Str::upper 方法将给定的字符串转换为大写:

  1. use Illuminate\Support\Str;
  2. $string = Str::upper('laravel');
  3. // LARAVEL

Str::ulid() {.collection-method}
php Str::ulid 方法生成一个 ULID:

  1. use Illuminate\Support\Str;
  2. return (string) Str::ulid();
  3. // 01gd6r360bp37zj17nxb55yv40

Str::uuid() {.collection-method}
php Str::uuid 方法生成一个 UUID(版本 4):

  1. use Illuminate\Support\Str;
  2. return (string) Str::uuid();

Str::wordCount() {.collection-method}
php Str::wordCount 方法返回字符串包含的单词数

  1. use Illuminate\Support\Str;
  2. Str::wordCount('Hello, world!'); // 2

Str::words() {.collection-method}
php Str::words 方法限制字符串中的单词数。 可以通过其第三个参数将附加字符串传递给此方法,以指定应将这个字符串附加到截断后的字符串末尾:

  1. use Illuminate\Support\Str;
  2. return Str::words('Perfectly balanced, as all things should be.', 3, ' >>>');
  3. // Perfectly balanced, as >>>

str() {.collection-method}
php str 函数返回给定字符串的新 php Illuminate\Support\Stringable 实例。 此函数等效于 php Str::of 方法:

  1. $string = str('Taylor')->append(' Otwell');
  2. // 'Taylor Otwell'

如果没有为 php str 函数提供参数,该函数将返回 php Illuminate\Support\Str 的实例:

  1. $snake = str()->snake('FooBar');
  2. // 'foo_bar'

trans() {.collection-method}
php trans 函数使用你的 语言文件 翻译给定的翻译键:

  1. echo trans('messages.welcome');

如果指定的翻译键不存在,php trans 函数将返回给定的键。 因此,使用上面的示例,如果翻译键不存在,php trans 函数将返回 php messages.welcome

trans_choice() {.collection-method}
php trans_choice 函数用词形变化翻译给定的翻译键:

  1. echo trans_choice('messages.notifications', $unreadCount);

如果指定的翻译键不存在,php trans_choice 函数将返回给定的键。 因此,使用上面的示例,如果翻译键不存在,php trans_choice 函数将返回 php messages.notifications

字符流处理

Fluent strings 提供了一个更流畅的、面向对象的接口来处理字符串值,与传统的字符串操作相比,允许你使用更易读的语法将多个字符串操作链接在一起。

after {.collection-method}
php after 方法返回字符串中给定值之后的所有内容。 如果字符串中不存在该值,则将返回整个字符串:

  1. use Illuminate\Support\Str;
  2. $slice = Str::of('This is my name')->after('This is');
  3. // ' my name'

afterLast {.collection-method}
php afterLast 方法返回字符串中最后一次出现给定值之后的所有内容。 如果字符串中不存在该值,则将返回整个字符串

  1. use Illuminate\Support\Str;
  2. $slice = Str::of('App\Http\Controllers\Controller')->afterLast('\\');
  3. // 'Controller'

append {.collection-method}
php append 方法将给定的值附加到字符串:

  1. use Illuminate\Support\Str;
  2. $string = Str::of('Taylor')->append(' Otwell');
  3. // 'Taylor Otwell'

ascii {.collection-method}
php ascii 方法将尝试将字符串音译为 ASCII 值:

  1. use Illuminate\Support\Str;
  2. $string = Str::of('ü')->ascii();
  3. // 'u'

basename {.collection-method}
php basename 方法将返回给定字符串的结尾名称部分:

  1. use Illuminate\Support\Str;
  2. $string = Str::of('/foo/bar/baz')->basename();
  3. // 'baz'

如果需要,你可以提供将从尾随组件中删除的「扩展名」:

  1. use Illuminate\Support\Str;
  2. $string = Str::of('/foo/bar/baz.jpg')->basename('.jpg');
  3. // 'baz'

before {.collection-method}
php before 方法返回字符串中给定值之前的所有内容:

  1. use Illuminate\Support\Str;
  2. $slice = Str::of('This is my name')->before('my name');
  3. // 'This is '

beforeLast {.collection-method}
php beforeLast 方法返回字符串中最后一次出现给定值之前的所有内容:

  1. use Illuminate\Support\Str;
  2. $slice = Str::of('This is my name')->beforeLast('is');
  3. // 'This '

between {.collection-method}
php between 方法返回两个值之间的字符串部分:

  1. use Illuminate\Support\Str;
  2. $converted = Str::of('This is my name')->between('This', 'name');
  3. // ' is my '

betweenFirst {.collection-method}
php betweenFirst 方法返回两个值之间字符串的最小可能部分:

  1. use Illuminate\Support\Str;
  2. $converted = Str::of('[a] bc [d]')->betweenFirst('[', ']');
  3. // 'a'

camel {.collection-method}
php camel 方法将给定的字符串转换为 php camelCase

  1. use Illuminate\Support\Str;
  2. $converted = Str::of('foo_bar')->camel();
  3. // fooBar

classBasename {.collection-method}
php classBasename 方法返回给定类的类名,删除了类的命名空间:

  1. use Illuminate\Support\Str;
  2. $class = Str::of('Foo\Bar\Baz')->classBasename();
  3. // Baz

contains {.collection-method}
php contains 方法确定给定的字符串是否包含给定的值。 此方法区分大小写:

  1. use Illuminate\Support\Str;
  2. $contains = Str::of('This is my name')->contains('my');
  3. // true

你还可以传递一个值数组来确定给定字符串是否包含数组中的任意值:

  1. use Illuminate\Support\Str;
  2. $contains = Str::of('This is my name')->contains(['my', 'foo']);
  3. // true

containsAll {.collection-method}
php containsAll 方法确定给定字符串是否包含给定数组中的所有值:

  1. use Illuminate\Support\Str;
  2. $containsAll = Str::of('This is my name')->containsAll(['my', 'name']);
  3. // true

dirname {.collection-method}
php dirname 方法返回给定字符串的父目录部分:

  1. use Illuminate\Support\Str;
  2. $string = Str::of('/foo/bar/baz')->dirname();
  3. // '/foo/bar'

如有必要,你还可以指定要从字符串中删除多少目录级别:

  1. use Illuminate\Support\Str;
  2. $string = Str::of('/foo/bar/baz')->dirname(2);
  3. // '/foo'

excerpt {.collection-method}
php excerpt 方法从字符串中提取与该字符串中短语的第一个实例匹配的摘录:

  1. use Illuminate\Support\Str;
  2. $excerpt = Str::of('This is my name')->excerpt('my', [
  3. 'radius' => 3
  4. ]);
  5. // '...is my na...'

php radius 选项默认为 php 100,允许你定义应出现在截断字符串每一侧的字符数。

此外,还可以使用 php omission 选项更改将添加到截断字符串之前和附加的字符串

  1. use Illuminate\Support\Str;
  2. $excerpt = Str::of('This is my name')->excerpt('name', [
  3. 'radius' => 3,
  4. 'omission' => '(...) '
  5. ]);
  6. // '(...) my name'

endsWith {.collection-method}
php endsWith 方法确定给定字符串是否以给定值结尾:

  1. use Illuminate\Support\Str;
  2. $result = Str::of('This is my name')->endsWith('name');
  3. // true

你还可以传递一个值数组来确定给定字符串是否以数组中的任何值结尾:

  1. use Illuminate\Support\Str;
  2. $result = Str::of('This is my name')->endsWith(['name', 'foo']);
  3. // true
  4. $result = Str::of('This is my name')->endsWith(['this', 'foo']);
  5. // false

exactly {.collection-method}
php exactly 方法确定给定的字符串是否与另一个字符串完全匹配:

  1. use Illuminate\Support\Str;
  2. $result = Str::of('Laravel')->exactly('Laravel');
  3. // true

explode {.collection-method}
php explode 方法按给定的分隔符拆分字符串并返回包含拆分字符串的每个部分的集合:

  1. use Illuminate\Support\Str;
  2. $collection = Str::of('foo bar baz')->explode(' ');
  3. // collect(['foo', 'bar', 'baz'])

finish {.collection-method}
php finish 方法将给定值的单个实例添加到字符串中(如果它尚未以该值结尾):
use Illuminate\Support\Str;

  1. $adjusted = Str::of('this/string')->finish('/');
  2. // this/string/
  3. $adjusted = Str::of('this/string/')->finish('/');
  4. // this/string/

headline {.collection-method}
php headline 方法会将由大小写、连字符或下划线分隔的字符串转换为空格分隔的字符串,每个单词的首字母大写:

  1. use Illuminate\Support\Str;
  2. $headline = Str::of('taylor_otwell')->headline();
  3. // Taylor Otwell
  4. $headline = Str::of('EmailNotificationSent')->headline();
  5. // Email Notification Sent

inlineMarkdown {.collection-method}
php inlineMarkdown 方法使用 CommonMark 将 GitHub 风格的 Markdown 转换为内联 HTML。 但是,与 php markdown 方法不同,它不会将所有生成的 HTML 包装在块级元素中:

  1. use Illuminate\Support\Str;
  2. $html = Str::of('**Laravel**')->inlineMarkdown();
  3. // <strong>Laravel</strong>

is {.collection-method}
php is 方法确定给定字符串是否与给定模式匹配。 星号可用作通配符值

  1. use Illuminate\Support\Str;
  2. $matches = Str::of('foobar')->is('foo*');
  3. // true
  4. $matches = Str::of('foobar')->is('baz*');
  5. // false

isAscii {.collection-method}
php isAscii 方法确定给定字符串是否为 ASCII 字符串:

  1. use Illuminate\Support\Str;
  2. $result = Str::of('Taylor')->isAscii();
  3. // true
  4. $result = Str::of('ü')->isAscii();
  5. // false

isEmpty {.collection-method}
php isEmpty 方法确定给定的字符串是否为空:

  1. use Illuminate\Support\Str;
  2. $result = Str::of(' ')->trim()->isEmpty();
  3. // true
  4. $result = Str::of('Laravel')->trim()->isEmpty();
  5. // false

isNotEmpty {.collection-method}
php isNotEmpty 方法确定给定的字符串是否不为空:

  1. use Illuminate\Support\Str;
  2. $result = Str::of(' ')->trim()->isNotEmpty();
  3. // false
  4. $result = Str::of('Laravel')->trim()->isNotEmpty();
  5. // true

isJson {.collection-method}
php isJson 方法确定给定的字符串是否是有效的 JSON:

  1. use Illuminate\Support\Str;
  2. $result = Str::of('[1,2,3]')->isJson();
  3. // true
  4. $result = Str::of('{"first": "John", "last": "Doe"}')->isJson();
  5. // true
  6. $result = Str::of('{first: "John", last: "Doe"}')->isJson();
  7. // false

isUlid {.collection-method}
php isUlid 方法确定给定的字符串是否一个 ULID:

  1. use Illuminate\Support\Str;
  2. $result = Str::of('01gd6r360bp37zj17nxb55yv40')->isUlid();
  3. // true
  4. $result = Str::of('Taylor')->isUlid();
  5. // false

isUuid {.collection-method}
php isUuid 方法确定给定的字符串是否是一个 UUID:

  1. use Illuminate\Support\Str;
  2. $result = Str::of('5ace9ab9-e9cf-4ec6-a19d-5881212a452c')->isUuid();
  3. // true
  4. $result = Str::of('Taylor')->isUuid();
  5. // false

kebab {.collection-method}
php kebab 方法转变给定的字符串为 php kebab-case:

  1. use Illuminate\Support\Str;
  2. $converted = Str::of('fooBar')->kebab();
  3. // foo-bar

lcfirst {.collection-method}
php lcfirst 方法返回给定的字符串的第一个字符为小写字母:

  1. use Illuminate\Support\Str;
  2. $string = Str::of('Foo Bar')->lcfirst();
  3. // foo Bar

length {.collection-method}
php length 方法返回给定字符串的长度:

  1. use Illuminate\Support\Str;
  2. $length = Str::of('Laravel')->length();
  3. // 7

limit {.collection-method}
php limit 方法将给定的字符串截断为指定的长度:

  1. use Illuminate\Support\Str;
  2. $truncated = Str::of('The quick brown fox jumps over the lazy dog')->limit(20);
  3. // The quick brown fox...

你也可以通过第二个参数来改变追加到末尾的字符串:

  1. use Illuminate\Support\Str;
  2. $truncated = Str::of('The quick brown fox jumps over the lazy dog')->limit(20, ' (...)');
  3. // The quick brown fox (...)

lower
php lower 方法将指定字符串转换为小写:

  1. use Illuminate\Support\Str;
  2. $result = Str::of('LARAVEL')->lower();
  3. // 'laravel'

ltrim
php ltrim 方法移除字符串左端指定的字符:

  1. use Illuminate\Support\Str;
  2. $string = Str::of(' Laravel ')->ltrim();
  3. // 'Laravel '
  4. $string = Str::of('/Laravel/')->ltrim('/');
  5. // 'Laravel/'

markdown {.collection-method}
php markdown 方法将 Github 风格的 Markdown 转换为 HTML:

  1. use Illuminate\Support\Str;
  2. $html = Str::of('# Laravel')->markdown();
  3. // <h1>Laravel</h1>
  4. $html = Str::of('# Taylor <b>Otwell</b>')->markdown([
  5. 'html_input' => 'strip',
  6. ]);
  7. // <h1>Taylor Otwell</h1>

mask
php mask 方法用重复字符掩盖字符串的一部分,可用于模糊处理字符串的某些段,例如电子邮件地址和电话号码:

  1. use Illuminate\Support\Str;
  2. $string = Str::of('taylor@example.com')->mask('*', 3);
  3. // tay***************

需要的话,你可以提供一个负数作为 php mask 方法的第三或第四个参数,这将指示该方法在距字符串末尾的给定距离处开始屏蔽:

  1. $string = Str::of('taylor@example.com')->mask('*', -15, 3);
  2. // tay***@example.com
  3. $string = Str::of('taylor@example.com')->mask('*', 4, -4);
  4. // tayl**********.com

match
php match 方法将会返回字符串中和指定正则表达式匹配的部分:

  1. use Illuminate\Support\Str;
  2. $result = Str::of('foo bar')->match('/bar/');
  3. // 'bar'
  4. $result = Str::of('foo bar')->match('/foo (.*)/');
  5. // 'bar'

matchAll
php matchAll 方法将会返回一个集合,该集合包含了字符串中与指定正则表达式匹配的部分

  1. use Illuminate\Support\Str;
  2. $result = Str::of('bar foo bar')->matchAll('/bar/');
  3. // collect(['bar', 'bar'])

如果你在正则表达式中指定了一个匹配组, Laravel 将会返回与该组匹配的集合:

  1. use Illuminate\Support\Str;
  2. $result = Str::of('bar fun bar fly')->matchAll('/f(\w*)/');
  3. // collect(['un', 'ly']);

如果没有找到任何匹配项,则返回空集合。

isMatch
php isMatch 方法用于判断给定的字符串是否与正则表达式匹配:

  1. use Illuminate\Support\Str;
  2. $result = Str::of('foo bar')->isMatch('/foo (.*)/');
  3. // true
  4. $result = Str::of('laravel')->match('/foo (.*)/');
  5. // false

newLine
php newLine 方法将给字符串追加换行的字符:

  1. use Illuminate\Support\Str;
  2. $padded = Str::of('Laravel')->newLine()->append('Framework');
  3. // 'Laravel
  4. // Framework'

padBoth
php padBoth 方法包装了 PHP 的 php str_pad 函数,在指定字符串的两侧填充上另一字符串,直至该字符串到达指定的长度:

  1. use Illuminate\Support\Str;
  2. $padded = Str::of('James')->padBoth(10, '_');
  3. // '__James___'
  4. $padded = Str::of('James')->padBoth(10);
  5. // ' James '

padLeft
The php padLeft 方法包装了 PHP 的 php str_pad 函数,在指定字符串的左侧填充上另一字符串,直至该字符串到达指定的长度:

  1. use Illuminate\Support\Str;
  2. $padded = Str::of('James')->padLeft(10, '-=');
  3. // '-=-=-James'
  4. $padded = Str::of('James')->padLeft(10);
  5. // ' James'

padRight
php padRight 方法包装了 PHP 的 php str_pad 函数,在指定字符串的右侧填充上另一字符串,直至该字符串到达指定的长度:

  1. use Illuminate\Support\Str;
  2. $padded = Str::of('James')->padRight(10, '-');
  3. // 'James-----'
  4. $padded = Str::of('James')->padRight(10);
  5. // 'James '

pipe
php pipe 方法将把字符串的当前值传递给指定的函数来转换字符串:

  1. use Illuminate\Support\Str;
  2. use Illuminate\Support\Stringable;
  3. $hash = Str::of('Laravel')->pipe('md5')->prepend('Checksum: ');
  4. // 'Checksum: a5c95b86291ea299fcbe64458ed12702'
  5. $closure = Str::of('foo')->pipe(function (Stringable $str) {
  6. return 'bar';
  7. });
  8. // 'bar'

plural
php plural 方法将单数形式的字符串转换为复数形式。该此函数支持 Laravel的复数化器支持的任何语言

  1. use Illuminate\Support\Str;
  2. $plural = Str::of('car')->plural();
  3. // cars
  4. $plural = Str::of('child')->plural();
  5. // children

你也可以给该函数提供一个整数作为第二个参数,用于检索字符串的单数或复数形式:

  1. use Illuminate\Support\Str;
  2. $plural = Str::of('child')->plural(2);
  3. // children
  4. $plural = Str::of('child')->plural(1);
  5. // child

prepend
php prepend 方法用于在指定字符串的开头插入另一指定字符串:

  1. use Illuminate\Support\Str;
  2. $string = Str::of('Framework')->prepend('Laravel ');
  3. // Laravel Framework

remove
php remove 方法用于从字符串中删除给定的值或值数组:

  1. use Illuminate\Support\Str;
  2. $string = Str::of('Arkansas is quite beautiful!')->remove('quite');
  3. // Arkansas is beautiful!

你也可以传递 php false 作为第二个参数以在删除字符串时忽略大小写。

replace
php replace 方法用于将字符串中的指定字符串替换为另一指定字符串:

  1. use Illuminate\Support\Str;
  2. $replaced = Str::of('Laravel 9.x')->replace('9.x', '10.x');
  3. // Laravel 10.x

replaceArray
php replaceArray 方法使用数组顺序替换字符串中的给定值:

  1. use Illuminate\Support\Str;
  2. $string = 'The event will take place between ? and ?';
  3. $replaced = Str::of($string)->replaceArray('?', ['8:30', '9:00']);
  4. // The event will take place between 8:30 and 9:00

replaceFirst
php replaceFirst 方法替换字符串中给定值的第一个匹配项:

  1. use Illuminate\Support\Str;
  2. $replaced = Str::of('the quick brown fox jumps over the lazy dog')->replaceFirst('the', 'a');
  3. // a quick brown fox jumps over the lazy dog

replaceLast
php replaceLast 方法替换字符串中给定值的最后一个匹配项:

  1. use Illuminate\Support\Str;
  2. $replaced = Str::of('the quick brown fox jumps over the lazy dog')->replaceLast('the', 'a');
  3. // the quick brown fox jumps over a lazy dog

replaceMatches
php replaceMatches 方法用给定的替换字符串替换与模式匹配的字符串的所有部分

  1. use Illuminate\Support\Str;
  2. $replaced = Str::of('(+1) 501-555-1000')->replaceMatches('/[^A-Za-z0-9]++/', '')
  3. // '15015551000'

php replaceMatches 方法还接受一个闭包,该闭包将在字符串的每个部分与给定模式匹配时调用,从而允许你在闭包中执行替换逻辑并返回替换的值:

  1. use Illuminate\Support\Str;
  2. use Illuminate\Support\Stringable;
  3. $replaced = Str::of('123')->replaceMatches('/\d/', function (Stringable $match) {
  4. return '['.$match[0].']';
  5. });
  6. // '[1][2][3]'

rtrim
php rtrim 方法修剪给定字符串的右侧:

  1. use Illuminate\Support\Str;
  2. $string = Str::of(' Laravel ')->rtrim();
  3. // ' Laravel'
  4. $string = Str::of('/Laravel/')->rtrim('/');
  5. // '/Laravel'

scan
php scan 方法根据 PHP 函数 sscanf 支持的格式把字符串中的输入解析为集合:

  1. use Illuminate\Support\Str;
  2. $collection = Str::of('filename.jpg')->scan('%[^.].%s');
  3. // collect(['filename', 'jpg'])

singular
php singular 方法将字符串转换为其单数形式。此函数支持 Laravel的复数化器支持的任何语言 :

  1. use Illuminate\Support\Str;
  2. $singular = Str::of('cars')->singular();
  3. // car
  4. $singular = Str::of('children')->singular();
  5. // child

slug {.collection-method}
php slug 方法从给定字符串生成 URL 友好的 “slug”:

  1. use Illuminate\Support\Str;
  2. $slug = Str::of('Laravel Framework')->slug('-');
  3. // laravel-framework

snake {.collection-method}
php snake 方法将给定字符串转换为 php snake_case

  1. use Illuminate\Support\Str;
  2. $converted = Str::of('fooBar')->snake();
  3. // foo_bar

split {.collection-method}
split 方法使用正则表达式将字符串拆分为集合:

  1. use Illuminate\Support\Str;
  2. $segments = Str::of('one, two, three')->split('/[\s,]+/');
  3. // collect(["one", "two", "three"])

squish {.collection-method}
php squish 方法删除字符串中所有无关紧要的空白,包括字符串之间的空白:

  1. use Illuminate\Support\Str;
  2. $string = Str::of(' laravel framework ')->squish();
  3. // laravel framework

start {.collection-method}
php start 方法将给定值的单个实例添加到字符串中,前提是该字符串尚未以该值开头:

  1. use Illuminate\Support\Str;
  2. $adjusted = Str::of('this/string')->start('/');
  3. // /this/string
  4. $adjusted = Str::of('/this/string')->start('/');
  5. // /this/string

startsWith {.collection-method}
php startsWith 方法确定给定字符串是否以给定值开头:

  1. use Illuminate\Support\Str;
  2. $result = Str::of('This is my name')->startsWith('This');
  3. // true

studly {.collection-method}
php studly 方法将给定字符串转换为 php StudlyCase

  1. use Illuminate\Support\Str;
  2. $converted = Str::of('foo_bar')->studly();
  3. // FooBar

substr {.collection-method}
php substr 方法返回由给定的起始参数和长度参数指定的字符串部分:

  1. use Illuminate\Support\Str;
  2. $string = Str::of('Laravel Framework')->substr(8);
  3. // Framework
  4. $string = Str::of('Laravel Framework')->substr(8, 5);
  5. // Frame

substrReplace {.collection-method}
php substrReplace 方法在字符串的一部分中替换文本,从第二个参数指定的位置开始替换第三个参数指定的字符数。将 php 0 传递给方法的第三个参数将在指定位置插入字符串,而不替换字符串中的任何现有字符:

  1. use Illuminate\Support\Str;
  2. $string = Str::of('1300')->substrReplace(':', 2);
  3. // 13:
  4. $string = Str::of('The Framework')->substrReplace(' Laravel', 3, 0);
  5. // The Laravel Framework

swap {.collection-method}
php swap 方法使用 PHP 的 php strtr 函数替换字符串中的多个值:

  1. use Illuminate\Support\Str;
  2. $string = Str::of('Tacos are great!')
  3. ->swap([
  4. 'Tacos' => 'Burritos',
  5. 'great' => 'fantastic',
  6. ]);
  7. // Burritos are fantastic!

tap {.collection-method}
php tap 方法将字符串传递给给定的闭包,允许你在不影响字符串本身的情况下检查字符串并与之交互。php tap 方法返回原始字符串,而不管闭包返回什么:

  1. use Illuminate\Support\Str;
  2. use Illuminate\Support\Stringable;
  3. $string = Str::of('Laravel')
  4. ->append(' Framework')
  5. ->tap(function (Stringable $string) {
  6. dump('String after append: '.$string);
  7. })
  8. ->upper();
  9. // LARAVEL FRAMEWORK

test {.collection-method}
php test 方法确定字符串是否与给定的正则表达式模式匹配:

  1. use Illuminate\Support\Str;
  2. $result = Str::of('Laravel Framework')->test('/Laravel/');
  3. // true

title {.collection-method}
php title 方法将给定字符串转换为 php title Case

  1. use Illuminate\Support\Str;
  2. $converted = Str::of('a nice title uses the correct case')->title();
  3. // A Nice Title Uses The Correct Case

trim {.collection-method}
php trim 方法修剪给定字符串:

  1. use Illuminate\Support\Str;
  2. $string = Str::of(' Laravel ')->trim();
  3. // 'Laravel'
  4. $string = Str::of('/Laravel/')->trim('/');
  5. // 'Laravel'

ucfirst {.collection-method}
php ucfirst 方法返回第一个字符大写的给定字符串

  1. use Illuminate\Support\Str;
  2. $string = Str::of('foo bar')->ucfirst();
  3. // Foo bar

ucsplit {.collection-method}
php ucsplit 方法将给定的字符串按大写字符分割为一个集合:

  1. use Illuminate\Support\Str;
  2. $string = Str::of('Foo Bar')->ucsplit();
  3. // collect(['Foo', 'Bar'])

upper {.collection-method}
php upper 方法将给定字符串转换为大写:

  1. use Illuminate\Support\Str;
  2. $adjusted = Str::of('laravel')->upper();
  3. // LARAVEL

when {.collection-method}
如果给定的条件为 php true,则 php when 方法调用给定的闭包。闭包将接收一个流畅字符串实例:

  1. use Illuminate\Support\Str;
  2. use Illuminate\Support\Stringable;
  3. $string = Str::of('Taylor')
  4. ->when(true, function (Stringable $string) {
  5. return $string->append(' Otwell');
  6. });
  7. // 'Taylor Otwell'

如果需要,可以将另一个闭包作为第三个参数传递给 php when 方法。如果条件参数的计算结果为 php false,则将执行此闭包。

whenContains {.collection-method}
php whenContains 方法会在字符串包含给定的值的前提下,调用给定的闭包。闭包将接收字符流处理实例:

  1. use Illuminate\Support\Str;
  2. use Illuminate\Support\Stringable;
  3. $string = Str::of('tony stark')
  4. ->whenContains('tony', function (Stringable $string) {
  5. return $string->title();
  6. });
  7. // 'Tony Stark'

如有必要,你可以将另一个闭包作为第三个参数传递给 php whenContains 方法。如果字符串不包含给定值,则此闭包将执行。

你还可以传递一个值数组来确定给定的字符串是否包含数组中的任何值:

  1. use Illuminate\Support\Str;
  2. use Illuminate\Support\Stringable;
  3. $string = Str::of('tony stark')
  4. ->whenContains(['tony', 'hulk'], function (Stringable $string) {
  5. return $string->title();
  6. });
  7. // Tony Stark

whenContainsAll {.collection-method}
php whenContainsAll 方法会在字符串包含所有给定的子字符串时,调用给定的闭包。闭包将接收字符流处理实例:

  1. use Illuminate\Support\Str;
  2. use Illuminate\Support\Stringable;
  3. $string = Str::of('tony stark')
  4. ->whenContainsAll(['tony', 'stark'], function (Stringable $string) {
  5. return $string->title();
  6. });
  7. // 'Tony Stark'

如有必要,你可以将另一个闭包作为第三个参数传递给 php whenContainsAll 方法。如果条件参数评估为 php false,则此闭包将执行。

whenEmpty {.collection-method}
如果字符串为空,php whenEmpty 方法将调用给定的闭包。如果闭包返回一个值,php whenEmpty 方法也将返回该值。如果闭包不返回值,则将返回字符流处理实例:

  1. use Illuminate\Support\Str;
  2. use Illuminate\Support\Stringable;
  3. $string = Str::of(' ')->whenEmpty(function (Stringable $string) {
  4. return $string->trim()->prepend('Laravel');
  5. });
  6. // 'Laravel'

whenNotEmpty {.collection-method}
如果字符串不为空,php whenNotEmpty 方法会调用给定的闭包。如果闭包返回一个值,那么 php whenNotEmpty 方法也将返回该值。如果闭包没有返回值,则返回字符流处理实例:

  1. use Illuminate\Support\Str;
  2. use Illuminate\Support\Stringable;
  3. $string = Str::of('Framework')->whenNotEmpty(function (Stringable $string) {
  4. return $string->prepend('Laravel ');
  5. });
  6. // 'Laravel Framework'

whenStartsWith {.collection-method}
如果字符串以给定的子字符串开头,php whenStartsWith 方法会调用给定的闭包。闭包将接收字符流处理实例:

  1. use Illuminate\Support\Str;
  2. use Illuminate\Support\Stringable;
  3. $string = Str::of('disney world')->whenStartsWith('disney', function (Stringable $string) {
  4. return $string->title();
  5. });
  6. // 'Disney World'

whenEndsWith {.collection-method}
如果字符串以给定的子字符串结尾,php whenEndsWith 方法会调用给定的闭包。闭包将接收字符流处理实例:

  1. use Illuminate\Support\Str;
  2. use Illuminate\Support\Stringable;
  3. $string = Str::of('disney world')->whenEndsWith('world', function (Stringable $string) {
  4. return $string->title();
  5. });
  6. // 'Disney World'

whenExactly {.collection-method}
如果字符串与给定字符串完全匹配,php whenExactly 方法会调用给定的闭包。闭包将接收字符流处理实例:

  1. use Illuminate\Support\Str;
  2. use Illuminate\Support\Stringable;
  3. $string = Str::of('laravel')->whenExactly('laravel', function (Stringable $string) {
  4. return $string->title();
  5. });
  6. // 'Laravel'

whenNotExactly {.collection-method}
如果字符串与给定字符串不完全匹配,php whenNotExactly方法将调用给定的闭包。闭包将接收字符流处理实例:

  1. use Illuminate\Support\Str;
  2. use Illuminate\Support\Stringable;
  3. $string = Str::of('framework')->whenNotExactly('laravel', function (Stringable $string) {
  4. return $string->title();
  5. });
  6. // 'Framework'

whenIs {.collection-method}
如果字符串匹配给定的模式,php whenIs 方法会调用给定的闭包。星号可用作通配符值。闭包将接收字符流处理实例:

  1. use Illuminate\Support\Str;
  2. use Illuminate\Support\Stringable;
  3. $string = Str::of('foo/bar')->whenIs('foo/*', function (Stringable $string) {
  4. return $string->append('/baz');
  5. });
  6. // 'foo/bar/baz'

whenIsAscii {.collection-method}
如果字符串是 7 位 ASCII,php whenIsAscii 方法会调用给定的闭包。闭包将接收字符流处理实例:

  1. use Illuminate\Support\Str;
  2. use Illuminate\Support\Stringable;
  3. $string = Str::of('laravel')->whenIsAscii(function (Stringable $string) {
  4. return $string->title();
  5. });
  6. // 'Laravel'

whenIsUlid {.collection-method}
如果字符串是有效的 ULID,php whenIsUlid 方法会调用给定的闭包。闭包将接收字符流处理实例:

  1. use Illuminate\Support\Str;
  2. $string = Str::of('01gd6r360bp37zj17nxb55yv40')->whenIsUlid(function (Stringable $string) {
  3. return $string->substr(0, 8);
  4. });
  5. // '01gd6r36'

whenIsUuid {.collection-method}
如果字符串是有效的 UUID,php whenIsUuid 方法会调用给定的闭包。闭包将接收字符流处理实例:

  1. use Illuminate\Support\Str;
  2. use Illuminate\Support\Stringable;
  3. $string = Str::of('a0a2a2d2-0b87-4a18-83f2-2529882be2de')->whenIsUuid(function (Stringable $string) {
  4. return $string->substr(0, 8);
  5. });
  6. // 'a0a2a2d2'

whenTest {.collection-method}
如果字符串匹配给定的正则表达式,php whenTest 方法会调用给定的闭包。闭包将接收字符流处理实例:

  1. use Illuminate\Support\Str;
  2. use Illuminate\Support\Stringable;
  3. $string = Str::of('laravel framework')->whenTest('/laravel/', function (Stringable $string) {
  4. return $string->title();
  5. });
  6. // 'Laravel Framework'

wordCount {.collection-method}
php wordCount 方法返回字符串包含的单词数:

  1. use Illuminate\Support\Str;
  2. Str::of('Hello, world!')->wordCount(); // 2

words {.collection-method}
php words 方法限制字符串中的字数。如有必要,可以指定附加到截断字符串的附加字符串:

  1. use Illuminate\Support\Str;
  2. $string = Str::of('Perfectly balanced, as all things should be.')->words(3, ' >>>');
  3. // Perfectly balanced, as >>>

URLs

action() {.collection-method}
php action 函数为给定的控制器操作生成 URL:

  1. use App\Http\Controllers\HomeController;
  2. $url = action([HomeController::class, 'index']);

如果该方法接受路由参数,则可以将它们作为第二个参数传递给该方法:

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

asset() {.collection-method}
php asset 函数使用请求的当前方案(HTTP 或 HTTPS)生成 URL:

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

你可以通过在php .env 文件中设置 php ASSET_URL 变量来配置资产 URL 主机。如果你将资产托管在外部服务(如 Amazon S3 或其他 CDN)上,这将非常有用:

  1. // ASSET_URL=http://example.com/assets
  2. $url = asset('img/photo.jpg'); // http://example.com/assets/img/photo.jpg

route() {.collection-method}
php route 函数为给定的 命名路由:

  1. $url = route('route.name');

如果路由接受参数,则可以将其作为第二个参数传递给函数:

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

默认情况下,php route 函数会生成一个绝对路径的 URL。 如果想生成一个相对路径 URL,你可以传递 php false 作为函数的第三个参数:

  1. $url = route('route.name', ['id' => 1], false);

secure_asset() {.collection-method}
php secure_asset 函数使用 HTTPS 为静态资源生成 URL:

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

secure_url() {.collection-method}
php secure_url 函数生成给定路径的完全限定 HTTPS URL。 可以在函数的第二个参数中传递额外的 URL 段:

  1. $url = secure_url('user/profile');
  2. $url = secure_url('user/profile', [1]);

to_route() {.collection-method}
php to_route 函数为给定的 命名路由 生成一个 重定向 HTTP 响应:

  1. return to_route('users.show', ['user' => 1]);

如有必要,你可以将应分配给重定向的 HTTP 状态代码和任何其他响应标头作为第三个和第四个参数传递给 php to_route 方法:

  1. return to_route('users.show', ['user' => 1], 302, ['X-Framework' => 'Laravel']);

url() {.collection-method}
php url 函数生成给定路径的完全限定 URL:

  1. $url = url('user/profile');
  2. $url = url('user/profile', [1]);

如果未提供路径,则返回一个 php Illuminate\Routing\UrlGenerator 实例:

  1. $current = url()->current();
  2. $full = url()->full();
  3. $previous = url()->previous();

杂项

abort() {.collection-method}
使用php abort 函数抛出一个 HTTP 异常 交给 异常处理

  1. abort(403);

你还可以提供应发送到浏览器的异常消息和自定义 HTTP 响应标头:

  1. abort(403, 'Unauthorized.', $headers);

abort_if() {.collection-method}
如果给定的布尔表达式的计算结果为 php true,则 php abort_if 函数会抛出 HTTP 异常:

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

php abort 方法一样,你还可以提供异常的响应文本作为函数的第三个参数,并提供自定义响应标头数组作为函数的第四个参数。

abort_unless() {.collection-method}
如果给定的布尔表达式的计算结果为 php false,则 php abort_unless 函数会抛出 HTTP 异常:

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

php abort 方法一样,你还可以提供异常的响应文本作为函数的第三个参数,并提供自定义响应标头数组作为函数的第四个参数。

app() {.collection-method}
php app 函数返回 服务容器 实例:

  1. $container = app();

你可以传递一个类或接口名称以从容器中解析它:

  1. $api = app('HelpSpot\API');

auth() {.collection-method}
php auth 函数返回一个 authenticator 实例。 你可以将它用作 php Auth 门面的替代品:

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

如果需要,你可以指定要访问的守卫实例:

  1. $user = auth('admin')->user();

back() {.collection-method}
php back 函数生成一个 重定向 HTTP 响应 到用户之前的位置:

  1. return back($status = 302, $headers = [], $fallback = '/');
  2. return back();

bcrypt() {.collection-method}
php bcrypt 函数 hashes 使用 Bcrypt 的给定值。 您可以使用此函数作为 php Hash 门面的替代方法:

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

blank() {.collection-method}
php blank 函数确定给定值是否为「空白」:

  1. blank('');
  2. blank(' ');
  3. blank(null);
  4. blank(collect());
  5. // true
  6. blank(0);
  7. blank(true);
  8. blank(false);
  9. // false

对于 php blank 的反转,请参阅 php filled 方法。

broadcast() {.collection-method}
php broadcast 函数 broadcasts 给定的 event 给它的听众:

  1. broadcast(new UserRegistered($user));
  2. broadcast(new UserRegistered($user))->toOthers();

cache() {.collection-method}
php cache 函数可用于从 cache 中获取值。 如果缓存中不存在给定的键,将返回一个可选的默认值:

  1. $value = cache('key');
  2. $value = cache('key', 'default');

你可以通过将键/值对数组传递给函数来将项目添加到缓存中。 你应该传递缓存值应被视为有效的秒数或持续时间:

  1. cache(['key' => 'value'], 300);
  2. cache(['key' => 'value'], now()->addSeconds(10));

class_uses_recursive() {.collection-method}
php class_uses_recursive 函数返回一个类使用的所有特征,包括其所有父类使用的特征:

  1. $traits = class_uses_recursive(App\Models\User::class);

collect() {.collection-method}
php collect 函数根据给定值创建一个 collection 实例:

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

config() {.collection-method}
php config 函数获取 configuration 变量的值。 可以使用「点」语法访问配置值,其中包括文件名和你希望访问的选项。 如果配置选项不存在,可以指定默认值并返回:

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

你可以通过传递键/值对数组在运行时设置配置变量。 但是请注意,此函数只会影响当前请求的配置值,不会更新您的实际配置值:

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

cookie() {.collection-method}
php cookie 函数创建一个新的 cookie 实例:

  1. $cookie = cookie('name', 'value', $minutes);

csrf_field() {.collection-method}
php csrf_field 函数生成一个 HTML php hidden 输入字段,其中包含 CSRF 令牌的值。 例如,使用 Blade 语法:

  1. {{ csrf_field() }}

csrf_token() {.collection-method}
php csrf_token 函数检索当前 CSRF 令牌的值:

  1. $token = csrf_token();

decrypt() {.collection-method}
php decrypt 函数 解密 给定的值。 你可以使用此函数作为 php Crypt 门面的替代方法:

  1. $password = decrypt($value);

dd() {.collection-method}
php dd 函数转储给定的变量并结束脚本的执行:

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

如果你不想停止脚本的执行,请改用 php dump 函数。

dispatch() {.collection-method}
php dispatch 函数将给定的 job 推送到 Laravel job queue:

  1. dispatch(new App\Jobs\SendEmails);

dump() {.collection-method}
php dump 函数转储给定的变量:

  1. dump($value);
  2. dump($value1, $value2, $value3, ...);

如果要在转储变量后停止执行脚本,请改用 php dd 函数。

encrypt() {.collection-method}
php encrypt 函数 encrypts 给定值。 你可以使用此函数作为 php Crypt 门面的替代方法:

  1. $secret = encrypt('my-secret-value');

env() {.collection-method}
php env 函数检索 环境变量 的值或返回默认值:

  1. $env = env('APP_ENV');
  2. $env = env('APP_ENV', 'production');

警告
如果你在部署过程中执行 php config:cache 命令,你应该确保只从配置文件中调用 php env 函数。 一旦配置被缓存,php .env 文件将不会被加载,所有对 php env 函数的调用都将返回 php null

event() {.collection-method}
php event 函数将给定的 event 分派给它的监听器:

  1. event(new UserRegistered($user));

fake() {.collection-method}
php fake 函数解析容器中的 Faker 单例,这在模型工厂、数据库填充、测试和原型视图中创建假数据时非常有用:

  1. @for($i = 0; $i < 10; $i++)
  2. <dl>
  3. <dt>Name</dt>
  4. <dd>{{ fake()->name() }}</dd>
  5. <dt>Email</dt>
  6. <dd>{{ fake()->unique()->safeEmail() }}</dd>
  7. </dl>
  8. @endfor

默认情况下,php fake 函数将使用 php config/app.php 配置文件中的 php app.faker_locale 配置选项; 但是,你也可以通过将语言环境传递给 php fake 函数来指定语言环境。 每个语言环境将解析一个单独的单例:

  1. fake('nl_NL')->name()

filled() {.collection-method}
php filled 函数确定给定值是否不是「空白」:

  1. filled(0);
  2. filled(true);
  3. filled(false);
  4. // true
  5. filled('');
  6. filled(' ');
  7. filled(null);
  8. filled(collect());
  9. // false

对于 php filled 的反转,请参阅 php blank 方法。

info() {.collection-method}
php info 函数会将信息写入应用程序的 log:

  1. info('Some helpful information!');

上下文数据数组也可以传递给函数:

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

logger() {.collection-method}
php logger 函数可用于将 php debug 级别的消息写入 log:

  1. logger('Debug message');

上下文数据数组也可以传递给函数:

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

如果没有值传递给函数,将返回一个 logger 实例:

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

method_field() {.collection-method}
php method_field 函数生成一个 HTML php hidden 输入字段,其中包含表单 HTTP 谓词的欺骗值。 例如,使用 Blade 语法:

  1. <form method="POST">
  2. {{ method_field('delete') }}
  3. </form>

now() {.collection-method}
php now 函数为当前时间创建一个新的 php Illuminate\Support\Carbon 实例:

  1. $now = now();

old() {.collection-method}
php old 函数 retrieves 一个 old input 值闪入Session :

  1. $value = old('value');
  2. $value = old('value', 'default');

由于作为 php old 函数的第二个参数提供的「默认值」通常是 Eloquent 模型的一个属性,Laravel 允许你简单地将整个 Eloquent 模型作为第二个参数传递给 php old 函数。 这样做时,Laravel 将假定提供给 old 函数的第一个参数是 Eloquent 属性的名称,该属性应被视为「默认值」:

  1. {{ old('name', $user->name) }}
  2. // 相当于...
  3. {{ old('name', $user) }}

optional() {.collection-method}
php optional 函数接受任何参数并允许您访问该对象的属性或调用方法。 如果给定对象为「null」,属性和方法将返回「null」而不是导致错误:

  1. return optional($user->address)->street;
  2. {!! old('name', optional($user)->name) !!}

php optional 函数也接受一个闭包作为它的第二个参数。 如果作为第一个参数提供的值不为空,则将调用闭包:

  1. return optional(User::find($id), function (User $user) {
  2. return $user->name;
  3. });

policy() {.collection-method}
php policy 方法检索给定类的 policy 实例:

  1. $policy = policy(App\Models\User::class);

redirect() {.collection-method}
php redirect 函数返回一个重定向 HTTP 响应,或者如果不带参数调用则返回重定向器实例:

  1. return redirect($to = null, $status = 302, $headers = [], $https = null);
  2. return redirect('/home');
  3. return redirect()->route('route.name');

report() {.collection-method}
php report 函数将使用您的 异常处理程序 报告异常:

  1. report($e);

php report 函数也接受一个字符串作为参数。 当给函数一个字符串时,该函数将创建一个异常,并将给定的字符串作为其消息:

  1. report('Something went wrong.');

report_if() {.collection-method}
如果给定条件为「true」,「report_if」函数将使用您的 异常处理程序 报告异常:

  1. report_if($shouldReport, $e);
  2. report_if($shouldReport, 'Something went wrong.');

report_unless() {.collection-method}
如果给定条件为 php falsephp report_unless 函数将使用你的 异常处理程序 报告异常:

  1. report_unless($reportingDisabled, $e);
  2. report_unless($reportingDisabled, 'Something went wrong.');

request() {.collection-method}
php request 函数返回当前的 request 实例或从当前请求中获取输入字段的值:

  1. $request = request();
  2. $value = request('key', $default);

rescue() {.collection-method}
php rescue 函数执行给定的闭包并捕获其执行期间发生的任何异常。 捕获的所有异常都将发送到你的异常处理程序; 但是,请求将继续处理:

  1. return rescue(function () {
  2. return $this->method();
  3. });

你还可以将第二个参数传递给「rescue」函数。 如果在执行闭包时发生异常,这个参数将是应该返回的「默认」值:

  1. return rescue(function () {
  2. return $this->method();
  3. }, false);
  4. return rescue(function () {
  5. return $this->method();
  6. }, function () {
  7. return $this->failure();
  8. });

resolve() {.collection-method}
php resolve 函数使用 服务容器 将给定的类或接口名称解析为实例:

  1. $api = resolve('HelpSpot\API');

response() {.collection-method}
php response 函数创建一个 response 实例或获取响应工厂的实例:

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

retry() {.collection-method}
php retry 函数尝试执行给定的回调,直到达到给定的最大尝试阈值。 如果回调没有抛出异常,则返回它的返回值。 如果回调抛出异常,它会自动重试。 如果超过最大尝试次数,将抛出异常:

  1. return retry(5, function () {
  2. // 尝试 5 次,两次尝试之间休息 100 ms...
  3. }, 100);

如果想手动计算两次尝试之间休眠的毫秒数,你可以将闭包作为第三个参数传递给 php retry 函数:

  1. use Exception;
  2. return retry(5, function () {
  3. // ...
  4. }, function (int $attempt, Exception $exception) {
  5. return $attempt * 100;
  6. });

为方便起见,你可以提供一个数组作为「retry」函数的第一个参数。 该数组将用于确定后续尝试之间要休眠多少毫秒:

  1. return retry([100, 200], function () {
  2. // 第一次重试时休眠 100 ms,第二次重试时休眠 200 ms...
  3. });

要仅在特定条件下重试,您可以将闭包作为第四个参数传递给 php retry 函数:

  1. use Exception;
  2. return retry(5, function () {
  3. // ...
  4. }, 100, function (Exception $exception) {
  5. return $exception instanceof RetryException;
  6. });

session() {.collection-method}
php session 函数可用于获取或设置 session 值:

  1. $value = session('key');

你可以通过将键/值对数组传递给函数来设置值:

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

如果没有值传递给函数,会话存储将被返回:

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

tap() {.collection-method}
php tap 函数接受两个参数:一个任意的 php $value 和一个闭包。 php $value 将传递给闭包,然后由 php tap 函数返回。 闭包的返回值是无关紧要的:

  1. $user = tap(User::first(), function (User $user) {
  2. $user->name = 'taylor';
  3. $user->save();
  4. });

如果没有闭包传递给 php tap 函数,你可以调用给定的 php $value 上的任何方法。 你调用的方法的返回值将始终为「$value」,无论该方法在其定义中实际返回什么。 例如,Eloquent 的 update 方法通常返回一个整数。 但是,我们可以通过 tap 函数链接 update 方法调用来强制该方法返回模型本身:

  1. $user = tap($user)->update([
  2. 'name' => $name,
  3. 'email' => $email,
  4. ]);

要向类添加 php tap 方法,你可以向类添加 php Illuminate\Support\Traits\Tappable trait。 这个特征的 php tap 方法接受一个闭包作为它唯一的参数。 对象实例本身将被传递给闭包,然后由 php tap 方法返回:

  1. return $user->tap(function (User $user) {
  2. // ...
  3. });

throw_if() {.collection-method}
如果给定的布尔表达式的计算结果为「真」,则 php throw_if 函数会抛出给定的异常:

  1. throw_if(! Auth::user()->isAdmin(), AuthorizationException::class);
  2. throw_if(
  3. ! Auth::user()->isAdmin(),
  4. AuthorizationException::class,
  5. '你不允许访问此页面。'
  6. );

throw_unless() {.collection-method}
如果给定的布尔表达式的计算结果为 php false,则 php throw_unless 函数会抛出给定的异常:

  1. throw_unless(Auth::user()->isAdmin(), AuthorizationException::class);
  2. throw_unless(
  3. Auth::user()->isAdmin(),
  4. AuthorizationException::class,
  5. '你不允许访问此页面。'
  6. );

today() {.collection-method}
如果给定的布尔表达式的计算结果为 php false,则 php throw_unless 函数会抛出给定的异常:

  1. $today = today();

trait_uses_recursive() {.collection-method}
php trait_uses_recursive 函数返回特征使用的所有 trait:

  1. $traits = trait_uses_recursive(\Illuminate\Notifications\Notifiable::class);

transform() {.collection-method}
如果值不是 blank,则 transform 函数会对给定值执行闭包,然后返回闭包的返回值:

  1. $callback = function (int $value) {
  2. return $value * 2;
  3. };
  4. $result = transform(5, $callback);
  5. // 10

默认值或闭包可以作为函数的第三个参数传递。 如果给定值为空,将返回此值:

  1. $result = transform(null, $callback, 'The value is blank');
  2. // The value is blank

validator() {.collection-method}
php validator 函数使用给定的参数创建一个新的 validator 实例。 你可以将它用作 php Validator 门面的替代品:

  1. $validator = validator($data, $rules, $messages);

value() {.collection-method}
php value 函数返回给定的值。 但是,如果将闭包传递给函数,则将执行闭包并返回其返回值:

  1. $result = value(true);
  2. // true
  3. $result = value(function () {
  4. return false;
  5. });
  6. // false

可以将其他参数传递给「value」函数。 如果第一个参数是一个闭包,那么附加参数将作为参数传递给闭包,否则它们将被忽略:

  1. $result = value(function (string $name) {
  2. return $name;
  3. }, 'Taylor');
  4. // 'Taylor'

view() {.collection-method}
php view 函数检索一个 view 实例:

  1. return view('auth.login');

with() {.collection-method}
php with 函数返回给定的值。 如果将闭包作为函数的第二个参数传递,则将执行闭包并返回其返回值:

  1. $callback = function (mixed $value) {
  2. return is_numeric($value) ? $value * 2 : 0;
  3. };
  4. $result = with(5, $callback);
  5. // 10
  6. $result = with(null, $callback);
  7. // 0
  8. $result = with(5, null);
  9. // 5

其他

基准测试

有时你可能希望快速测试应用程序某些部分的性能。 在这些情况下,您可以使用 Benchmark 支持类来测量给定回调完成所需的毫秒数:

  1. <?php
  2. use App\Models\User;
  3. use Illuminate\Support\Benchmark;
  4. Benchmark::dd(fn () => User::find(1)); // 0.1 ms
  5. Benchmark::dd([
  6. 'Scenario 1' => fn () => User::count(), // 0.5 ms
  7. 'Scenario 2' => fn () => User::all()->count(), // 20.0 ms
  8. ]);

默认情况下,给定的回调将执行一次(一次迭代),并且它们的持续时间将显示在浏览器/控制台中。

要多次调用回调,你可以将回调应调用的迭代次数指定为方法的第二个参数。 当多次执行回调时,「基准」类将返回在所有迭代中执行回调所花费的平均毫秒数:

  1. Benchmark::dd(fn () => User::count(), iterations: 10); // 0.5 ms

管道

Laravel 的 Pipeline 门面提供了一种便捷的方式来通过一系列可调用类、闭包或可调用对象「管道」给定输入,让每个类都有机会检查或修改输入并调用管道中的下一个可调用对象:

  1. use Closure;
  2. use App\Models\User;
  3. use Illuminate\Support\Facades\Pipeline;
  4. $user = Pipeline::send($user)
  5. ->through([
  6. function (User $user, Closure $next) {
  7. // ...
  8. return $next($user);
  9. },
  10. function (User $user, Closure $next) {
  11. // ...
  12. return $next($user);
  13. },
  14. ])
  15. ->then(fn (User $user) => $user);

如你所见,管道中的每个可调用类或闭包都提供了输入和一个 php $next 闭包。 调用 php $next 闭包将调用管道中的下一个可调用对象。 你可能已经注意到,这与 middleware 非常相似。

当管道中的最后一个可调用对象调用 php $next 闭包时,提供给 php then 方法的可调用对象将被调用。 通常,此可调用对象将简单地返回给定的输入。

当然,如前所述,你不仅限于为管道提供闭包。 你还可以提供可调用的类。 如果提供了类名,该类将通过 Laravel 的 服务容器 实例化,允许将依赖项注入可调用类:

  1. $user = Pipeline::send($user)
  2. ->through([
  3. GenerateProfilePhoto::class,
  4. ActivateSubscription::class,
  5. SendWelcomeEmail::class,
  6. ])
  7. ->then(fn (User $user) => $user);

彩票

Laravel 的 Lottery 类可用于根据一组给定的赔率执行回调。 当你只想为一定比例的传入请求执行代码时,这会特别有用:

  1. use Illuminate\Support\Lottery;
  2. Lottery::odds(1, 20)
  3. ->winner(fn () => $user->won())
  4. ->loser(fn () => $user->lost())
  5. ->choose();

你可以将 Laravel 的彩票类与其他 Laravel 功能结合使用。 例如,你可能希望只向异常处理程序报告一小部分慢速查询。 而且,由于 Lottery 类是可调用的,我们可以将类的实例传递给任何接受可调用对象的方法:

  1. use Carbon\CarbonInterval;
  2. use Illuminate\Support\Facades\DB;
  3. use Illuminate\Support\Lottery;
  4. DB::whenQueryingForLongerThan(
  5. CarbonInterval::seconds(2),
  6. Lottery::odds(1, 100)->winner(fn () => report('Querying > 2 seconds.')),
  7. );

测试彩票
Laravel 提供了一些简单的方法来让你轻松测试应用程序的 Lottery 调用:

  1. // 彩票总是取胜...
  2. Lottery::alwaysWin();
  3. // 彩票总是获败...
  4. Lottery::alwaysLose();
  5. // 彩票会先赢后输,最后恢复到正常行为...
  6. Lottery::fix([true, false]);
  7. // 彩票将恢复到正常行为...
  8. Lottery::determineResultsNormally();