ThinkPHP6.0使用twig作为模板引擎及自定义过滤器

简介: ThinkPHP6.0使用twig作为模板引擎及自定义过滤器

ThinkPHP自带的模板引擎用起来很不顺手,好在找到了一个和Jinja2很类似的一个一个模板引擎Twig,可以集成到ThinkPHP中。


文档:


https://github.com/yunwuxin/think-twig

https://twig.symfony.com/doc/3.x/

安装

composer require yunwuxin/think-twig

修改配置config/view.php


<?php
return [
    // 模板引擎类型使用Think
    // 'type'          => 'Think',
    'type'          => 'Twig',
    // 模板后缀(可以不修改,建议修改,IDE中有语法高亮提示)
    // 'view_suffix'   => 'html',
    'view_suffix'   => 'twig',  
  // 自定义过滤器
    'filters'       => config('twig_filters')
  // 其他配置项省略
];

自定义过滤器

config/twig_filters.php

<?php
// +----------------------------------------------------------------------
// | 自定义twig模板过滤器
// +----------------------------------------------------------------------
return [
    // 处理静态文件url
    "make_static_url" => function ($url) {
        // 静态文件路径,处理开发、生产环境
        $static_url = config('app.static_url');
        // 应用版本配置, 处理静态文件缓存问题
        $app_version = config('version.app_version');
        return "$static_url$url?t=$app_version";
    }
];

模板中使用自定义过滤器

<link href="{{ '/css/index.css' | make_static_url }}" rel="stylesheet

相关文章
uniapp自定义过滤器filter.js
uniapp自定义过滤器filter.js
130 0
|
4月前
|
Python
配置模板引擎
【8月更文挑战第6天】配置模板引擎。
48 7
|
前端开发 JavaScript 搜索推荐
webpack进阶篇(十七):静态资源内联
webpack进阶篇(十七):静态资源内联
411 0
webpack进阶篇(十七):静态资源内联
|
7月前
|
JavaScript 前端开发
Vue过滤器(filters)的简单使用
Vue过滤器(filters)的简单使用
Jinja2 中常用的过滤器
Jinja2 是 Python 中流行的模板引擎之一,具有可扩展性和灵活性。
|
JavaScript 前端开发 搜索推荐
语义化 HTML 编写一个原生 Web Components 组件
使用语义化 HTML 编写一个原生 Web Components 组件
|
Java Spring
常见的模版引擎
常见的模版引擎
80 0
|
前端开发
symfony2框架配置页面
symfony2框架配置页面
139 0
symfony2框架配置页面
symfony框架Twig模板语言的使用
symfony框架Twig模板语言的使用
164 0
symfony框架Twig模板语言的使用
ThinkPHP6.0使用twig作为模板引擎
ThinkPHP6.0使用twig作为模板引擎
200 0