Maison > cadre php > Laravel > Composant de vue personnalisé Laravel

Composant de vue personnalisé Laravel

藏色散人
Libérer: 2019-10-29 13:49:43
avant
3235 Les gens l'ont consulté

Laravel 的视图合成器可将数据与指定视图绑定在一起,避免了重复编写代码。

View::composer('profile', 'App\Http\View\Composers\ProfileComposer');
Copier après la connexion

由于数据的生成和渲染是分开进行的,理解起来不够直观。因此,可以采用视图组件的方式将两者进行封装。

<?php
namespace App\ViewComponents;
use Illuminate\Contracts\Support\Htmlable;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\View;
class ExampleComponent implements Htmlable
{
    private $color;
    private $request;
    public function __construct(Request $request, string $color)
    {
        $this->color = $color;
        $this->request = $request;
    }
    public function toHtml()
    {   
        return View::make(&#39;example&#39;)
            ->with(&#39;color&#39;, $this->color)
            ->render();
    }
}
Copier après la connexion

在视图中使用

{{ app()->makeWith(App\ViewComponents\ExampleComponent::class,[&#39;color&#39; => &#39;green&#39;])->toHtml() }}
Copier après la connexion

封装指令

Blade::directive(&#39;render&#39;, function ($expression) {
    list($class, $params) = explode(&#39;,&#39;, $expression, 2);
    $class = "App\\ViewComponents\\".trim($class, &#39;\&#39;" &#39;);
    return "<?php echo app()->makeWith(&#39;$class&#39;, $params)->toHtml(); ?>";
});
Copier après la connexion

使用指令

@render(&#39;ExampleComponent&#39;, [&#39;color&#39; => &#39;green&#39;])
Copier après la connexion

参考资料

spatie/laravel-view-components: A better way to connect data with view rendering in Laravel
Introducing View Components in Laravel, an alternative to View Composers - Laravel News
Copier après la connexion

更多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!

Étiquettes associées:
source:learnku.com
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal