>  기사  >  백엔드 개발  >  CakePHP와 함께 블레이드를 사용하는 방법은 무엇입니까?

CakePHP와 함께 블레이드를 사용하는 방법은 무엇입니까?

WBOY
WBOY원래의
2023-06-04 10:01:461470검색

CakePHP는 인기 있는 PHP MVC 프레임워크이고 Blade는 Laravel 프레임워크에서 매우 인기 있는 템플릿 엔진 중 하나입니다. CakePHP에는 강력한 템플릿 엔진이 포함되어 있지만 때로는 기본 템플릿 엔진을 대체하기 위해 다른 템플릿 엔진을 사용하고 싶을 수도 있습니다.

이 기사에서는 Blade를 사용하려는 일부 개발자에게 도움이되기를 바라며 CakePHP 3에서 Blade 템플릿 엔진을 사용하는 방법을 소개하겠습니다.

  1. Blade 설치

먼저 Blade를 설치해야 하는데 Composer를 통해 설치가 가능합니다. 프로젝트 루트 디렉터리의 작곡가.json 파일에 종속성을 추가합니다.

{
    "require": {
        "illuminate/view": "5.8.*"
    }
}

그런 다음 터미널에서 composer update 명령을 실행하여 종속성을 설치합니다.

  1. CakePHP 구성

다음으로 블레이드 템플릿 엔진을 사용하도록 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 클래스를 사용하여 템플릿을 렌더링합니다.

  1. 템플릿 파일 생성

블레이드 엔진 구성 및 정의가 완료되었으니 이제 템플릿 파일 작성을 시작하겠습니다. 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') 지시문에 삽입됩니다.

  1. Rendering Templates

이제 블레이드 엔진을 호출하여 컨트롤러에서 템플릿을 렌더링할 수 있습니다. 예를 들어 PagesController에 다음 코드를 추가합니다.

public function home()
{
    $this->getViewBuilder()->setClassName('CakeBlade.Blade');
    $this->set(compact('data'));
    $this->render('home');
}

템플릿을 렌더링하기 전에 사용되는 뷰 클래스를 지정해야 합니다. 그런 다음 데이터를 뷰에 전달하고 로드할 템플릿 파일 이름을 지정합니다.

  1. 테스트 실행

이제 브라우저의 페이지를 방문하여 Blade가 제대로 작동하는지 확인할 수 있습니다. 주소 표시줄에 http://localhost/cake_blade/pages/home과 같이 파일 이름을 입력하면 방금 작성한 블레이드 템플릿이 표시되며 이는 템플릿 파일에 정의한 것과 동일합니다.

요약

이 글에서는 CakePHP 3의 블레이드 템플릿 엔진을 사용하여 기본 템플릿 엔진을 대체하는 방법을 소개했습니다. 이러한 방식으로 우리는 Blade가 제공하는 강력한 구문과 기능을 사용하여 웹 애플리케이션을 개발할 수 있습니다. 기능이 풍부한 템플릿 엔진을 찾고 있다면 Blade가 좋은 선택입니다.

위 내용은 CakePHP와 함께 블레이드를 사용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.