CakePHP는 인기 있는 PHP MVC 프레임워크이고 Blade는 Laravel 프레임워크에서 매우 인기 있는 템플릿 엔진 중 하나입니다. CakePHP에는 강력한 템플릿 엔진이 포함되어 있지만 때로는 기본 템플릿 엔진을 대체하기 위해 다른 템플릿 엔진을 사용하고 싶을 수도 있습니다.
이 기사에서는 Blade를 사용하려는 일부 개발자에게 도움이되기를 바라며 CakePHP 3에서 Blade 템플릿 엔진을 사용하는 방법을 소개하겠습니다.
먼저 Blade를 설치해야 하는데 Composer를 통해 설치가 가능합니다. 프로젝트 루트 디렉터리의 작곡가.json 파일에 종속성을 추가합니다.
{ "require": { "illuminate/view": "5.8.*" } }
그런 다음 터미널에서 composer update
명령을 실행하여 종속성을 설치합니다.
다음으로 블레이드 템플릿 엔진을 사용하도록 CakePHP를 구성해야 합니다. 먼저 config/app.php 파일에 다음 코드를 추가합니다:
'View' => [ 'className' => 'CakeViewView', 'viewPath' => APP . 'Template/', 'layoutPath' => APP . 'Template/Layout/', 'templatePath' => APP . 'Template/', 'cachePath' => CACHE . 'views/', 'helpers' => [ 'Html', 'Form', 'Url' ], 'useRenderCache' => false, 'engine' => [ 'Blade' => [ 'className' => 'CakeBladeBladeEngine', 'options' => [ 'cache_path' => TMP . 'blade_cache', 'view_path' => APP . 'Template/', 'auto_reload' => true ] ] ] ]
이 구성 배열에서는 CakePHP의 뷰 구성을 지정하고 "Blade"라는 템플릿 엔진을 추가합니다. Blade의 옵션에서는 캐시 경로, 보기 경로 및 템플릿을 자동으로 다시 로드할지 여부를 지정합니다.
다음으로 src/View/BladeEngine.php에 블레이드 엔진을 정의하는 파일을 추가해야 합니다.
<?php namespace CakeBlade; use CakeViewEngineEngine; use IlluminateViewCompilersBladeCompiler; use IlluminateViewEnginesCompilerEngine; use IlluminateViewFactory; use IlluminateViewFileViewFinder; class BladeEngine extends Engine { public $Factory; public function __construct($view = null, $layout = null) { parent::__construct($view, $layout); $config = CakeCoreConfigure::read('App'); $viewPath = $config['Template']['templatePath']; $cachePath = $config['engine']['Blade']['options']['cache_path']; $this->Factory = new Factory(new FileViewFinder([$viewPath]), new CompilerEngine(new BladeCompiler(new Filesystem, $cachePath))); } public function render($template, $layout = null) { return $this->Factory->make($template, compact('data'))->render(); } }
이 클래스에서는 CakePHP의 Engine 클래스를 상속하는 BladeEngine 클래스를 정의합니다. 생성자에서 CakePHP의 구성을 사용하여 뷰 경로를 읽고 Blade가 템플릿 파일을 찾을 수 있도록 이를 Blade의 생성자에 전달합니다. 또한 성능 향상을 위해 캐시 경로를 추가했습니다. 렌더링 기능에서는 Blade의 Factory 클래스를 사용하여 템플릿을 렌더링합니다.
블레이드 엔진 구성 및 정의가 완료되었으니 이제 템플릿 파일 작성을 시작하겠습니다. CakePHP에서는 src/Template/ 디렉토리에 템플릿 파일을 생성할 수 있습니다.
예를 들어 src/Template/Pages/home.blade.php에서 간단한 블레이드 템플릿을 만들 수 있습니다.
@extends('Layout.default') @section('content') <div class="jumbotron"> <h1>Welcome to CakeBlade</h1> <p>CakePHP 3 + Blade Template Engine.</p> <p><a class="btn btn-primary btn-lg" href="#" role="button">Learn more</a></p> </div> @endsection
이 템플릿에서는 @extends를 사용하여 사용할 레이아웃을 지정합니다. @section과 @endsection 사이의 내용은 레이아웃의 @yield('content') 지시문에 삽입됩니다.
이제 블레이드 엔진을 호출하여 컨트롤러에서 템플릿을 렌더링할 수 있습니다. 예를 들어 PagesController에 다음 코드를 추가합니다.
public function home() { $this->getViewBuilder()->setClassName('CakeBlade.Blade'); $this->set(compact('data')); $this->render('home'); }
템플릿을 렌더링하기 전에 사용되는 뷰 클래스를 지정해야 합니다. 그런 다음 데이터를 뷰에 전달하고 로드할 템플릿 파일 이름을 지정합니다.
이제 브라우저의 페이지를 방문하여 Blade가 제대로 작동하는지 확인할 수 있습니다. 주소 표시줄에 http://localhost/cake_blade/pages/home과 같이 파일 이름을 입력하면 방금 작성한 블레이드 템플릿이 표시되며 이는 템플릿 파일에 정의한 것과 동일합니다.
요약
이 글에서는 CakePHP 3의 블레이드 템플릿 엔진을 사용하여 기본 템플릿 엔진을 대체하는 방법을 소개했습니다. 이러한 방식으로 우리는 Blade가 제공하는 강력한 구문과 기능을 사용하여 웹 애플리케이션을 개발할 수 있습니다. 기능이 풍부한 템플릿 엔진을 찾고 있다면 Blade가 좋은 선택입니다.
위 내용은 CakePHP와 함께 블레이드를 사용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!