Maison  >  Article  >  développement back-end  >  Découvrez les trésors cachés de Laravel

Découvrez les trésors cachés de Laravel

WBOY
WBOYoriginal
2023-08-28 16:45:02672parcourir

揭开 Laravel 隐藏的宝藏

De nombreux développeurs utilisant Laravel n'ont peut-être fait qu'effleurer la surface de ce que le framework a à offrir. Bien que la documentation couvre les cas d'utilisation les plus courants et les fonctionnalités évidentes, elle ne couvre pas tout.

Ne vous méprenez pas, la documentation est excellente, c'est juste qu'il y a tellement de choses que vous pouvez faire qu'il est difficile de documenter tout. Nous allons donc jeter un œil à certains des joyaux cachés qui se cachent dans Laravel.

Vue en cascade

Heure disponible : v4.0.0

Enregistrement : Non

Les vues peuvent être mises en cascade comme des fichiers de configuration. Les vues en cascade sont très utiles lors du développement de systèmes de thèmes évolutifs. Considérez la structure de répertoires suivante.

/app
    /views
        /blog
            /index.blade.php
/themes
    /default
        /views
            /blog
                /index.blade.php
            /theme.blade.php

L'idée est que lorsque nous return View::make('theme::blog.index'); 时,它会首先在 themes/default/views 目录中查找,如果找不到的话找到视图,回退到 app/views.

Pour ce faire, nous utilisons View::addNamespace pour enregistrer notre propre espace de noms aux deux emplacements.

View::addNamespace('theme', [
    base_path().'/themes/default/views',
    app_path().'/views'
]);

Collection

Heure disponible : v4.0.0

Enregistrement : Partie

Les collections sont un excellent moyen d'interagir avec et de gérer les tableaux. Les collections disposent de diverses méthodes pratiques et implémentent de nombreuses interfaces utiles, telles que ArrayableInterfaceIteratorAggregateJsonableInterface.

Supposons que nous construisions un petit moteur de blog qui utilise des fichiers plats pour le stockage. Nous voulons pouvoir effectuer des opérations telles que le tri, le filtrage et la pagination.

La mise en œuvre d'un moteur de blog dépasse le cadre de cet article, mais supposons que nous ayons une nouvelle instance du tableau $articles,并且该数组的每个成员都是 Article 类的实例。然后我们需要做的就是获取 Collection et que nous lui fournissions notre tableau de publications.

$articles = new Illuminate\Support\Collection($arrayOfArticles);

Trier

Grâce aux collections, nous pouvons trier les articles. Trions les articles et affichons d'abord les plus récemment mis à jour. Pour les besoins de cet article, nous supposons que lors du chargement d'un article depuis le système de fichiers, nous définissons l'attribut updatedAt sur l'heure de la dernière modification du fichier.

$articles->sortByDesc(function ($article) { 
    return $article->updatedAt; 
});
La méthode

sortBysortByDesc accepte un rappel qui doit renvoyer une valeur pouvant être utilisée pour trier la collection. Dans notre cas, nous pouvons simplement renvoyer l'heure de la dernière modification de l'article, et la collection peut être triée en fonction de cette heure.

Filtre

Semblable au tri, nous pouvons également utiliser des collections pour filtrer nos articles, tout comme la clause WHERE dans MySQL. Filtrons nos articles en fonction des recherches qui ont pu être effectuées.

<?php

$searchQuery = 'Laravel rocks!';

$results = $articles->filter(function ($article) use ($searchQuery) {
    return preg_match(sprintf('/%s/m', $searchQuery), $article->body);
});

filter 方法实际上返回 IlluminateSupportCollection 的新实例,因此我们需要将其分配给 $resultsVariables. Cette nouvelle collection ne contiendra que des articles mentionnant "Laravel rock!"

Pagination

Grâce à cette collection, nous pouvons paginer les articles afin qu'il n'y ait pas trop d'articles sur une seule page.

$perPage = 1;

$page = Input::get('page', 1);

if ($page > ($articles->count() / $perPage)) {
    $page = 1;
}

$pageOffset = ($page * $perPage) - $perPage;

$results = $articles->slice($pageOffset, $perPage);

Utilisez slice 方法,我们提取集合中的一部分文章并将其分配给 $results variables.

Cet exemple peut être implémenté davantage en créant une nouvelle instance de la classe Paginator de Laravel. De cette façon, il peut générer tous les numéros de page et liens pour vous.

Il y a encore plus à venir !

Nous pouvons obtenir un article au hasard :

$article = $articles->random();

Nous pouvons également parcourir notre collection d'articles comme s'il s'agissait d'un tableau régulier. Tout cela grâce à l'interface IteratorAggregateArrayIterator.

foreach ($articles as $article) {
    echo $article->body;
}

Nous pouvons même convertir des articles en tableaux réguliers ou en leur représentation JSON.

$array = $articles->toArray();
$json = $articles->toJson();

L'une des méthodes les plus intéressantes est probablement groupBy, qui nous permet de regrouper les articles par clés spécifiques. Imaginez que chaque article comporte des métadonnées en haut qui sont analysées et supprimées du corps de l'article.

Bien que l'analyse de ces métadonnées dépasse le cadre de cet article, nous supposons qu'elles sont analysées et constituent une propriété sur l'instance Article. Vous pouvez ensuite utiliser Article 实例上的属性。然后,您可以使用 groupBy pour regrouper vos articles par catégorie dans laquelle ils ont été publiés.

$results = $articles->groupBy('category');

Tous les articles partageant la même catégorie seront regroupés. Ensuite, vous pouvez obtenir des articles dans une catégorie spécifique.

foreach ($results->get('tutorial') as $article) { 
    echo $article->body; 
}

Les collections sont l'un des meilleurs joyaux cachés que Laravel a à offrir.

Filtre d'expression régulière

Heure disponible : v4.1.19

Enregistrement : Non

Le filtrage des itinéraires dans Laravel est une tâche courante que beaucoup d'entre nous effectuent dans tous nos projets. Les filtres vous permettent d'effectuer des tâches telles que l'authentification des utilisateurs ou la limitation du débit avant ou après le déclenchement d'un itinéraire. Nous utilisons Route::filter 创建过滤器,并可以将它们应用于单个路由、路由组,或者使用 Route::when et l'appliquons au motif correspondant.

Route::filter('restricted', function($route, $request, $group)
{
    // Restrict user access based on the value of $group
});

Route::when('admin/*', 'restricted:admin');

在此示例中,我们创建一个 restricted 过滤器,它需要一个参数 $group$route$request 参数始终提供给 before 过滤器。

但是如果我们想要更大的灵活性怎么办?假设我们想要将过滤器应用于所有 admin 路由除了 admin/login。我们可以使用路线组并将相关路线移至组外。或者我们可以使用 Route::whenRegex 并编写我们自己的正则表达式。

Route::whenRegex('/^admin(\/(?!login)\S+)?$/', 'restricted:admin');

此正则表达式只是确保它仅适用于以 admin 开头且后面不跟 /login 的路由,但后面可以跟任何其他内容。出色的。现在,我们将 restricted:admin 过滤器应用于除 admin/login 路由之外的所有路由。

消息包

可用时间: v4.0.0

记录:部分

毫无疑问,您已经使用 Illuminate\Support\MessageBag 一段时间了,甚至没有意识到。 MessageBag 扮演的最大角色是在使用 Laravel 内置验证器时包含所有验证错误。

每个视图中都有一个 $errors 变量,该变量包含空的 MessageBag 实例或使用 Redirect::to('/')->withErrors($validator); 刷新到会话的实例

当在特定输入下方显示错误消息时,很多人可能会在表单中执行类似的操作。

{{ Form::text('username', null) }}
@if($errors->has('username'))
    <div class="error">{{ $errors->first('username') }}></div>;
@endif

您实际上可以完全删除 if 语句,并使用 first 方法的第二个参数将消息包装在 div 中。

    {{ Form::text('username', null) }}
    {{ $errors->first('username', '<div class="error">:message</div>') }}

好多了,好多了!

流利

可用时间: v3.0.0

记录:部分

Fluent 类已经存在很长时间了,当使用模式生成器创建迁移时,它实际上在框架本身内使用。 Laravel 3 和 Laravel 4 之间,类本身几乎没有变化,唯一大的区别是多了一些接口。

要使用 Fluent 类,您所需要做的就是获取一个实例,然后就可以了。

$user = new Illuminate\Support\Fluent;
$user->name('Jason')->country('Australia')->subscriber();

该实例现在定义了 3 个属性:name,值为 Jasoncountry,值为 Australiasubscriber,值为布尔值 true

在 Laravel 4.1 之前,您只能从实例中真正设置和获取属性。从 Laravel 4.1 开始,您可以使用 toArraytoJson 方法分别获取属性数组及其 JSON 表示形式。

从 Laravel 4.2 开始,该类还实现了 JsonSerialized 接口,这意味着您可以将实例直接传递到 json_encode 中。

还有更多!

我们已经研究了 Laravel 框架的几个有用的精华。但是,正如您所猜测的,框架内还有更多内容。

了解 Laravel 可能提供的其他功能的最佳方法是深入研究源代码。它并不像您想象的那么可怕,您将学到很多关于您正在构建的框架的知识。

如果您发现了其他宝石,请随时在评论中分享!

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn