使用 Twig 通过 PHP 渲染 Markdown

使用 twig 通过 php 渲染 markdown

twig 是使用 symfony 开发 web 应用程序时渲染 html 的首选模板引擎。
然而,twig 的灵活性不仅仅限于生成 html 页面。它可以成为跨多个渠道交付内容的强大工具,例如生成 markdown 文件、json 输出,甚至纯文本,所有这些都来自同一组内容。

这种适应性使您可以为不同的频道创建内容。

您可以使用 twig 生成 html、markdown、json、文本等

用例:使用 symfony 获取并渲染配方为 markdown

在此示例中,我们使用 symfony 的 http 客户端从外部 api (https://dummyjson.com/recipes/1) 获取配方,并使用 twig 将其呈现为 markdown 文档。
这种方法展示了如何结合 symfony 强大的软件包(例如用于外部数据检索的 symfony http 客户端和用于渲染视图的 twig)来跨多个渠道交付内容,例如命令行工具中的 markdown 报告。

我们要构建的命令/脚本从 api 中获取食谱数据(标题、描述、成分和说明),对其进行处理,然后使用 twig 以结构化 markdown 格式输出内容。这个实际用例说明了如何在 web 模板之外使用 twig,使其能够生成各种格式的内容。

所以,我们将使用:

symfony console 用于构建命令行工具的组件 https://symfony.com/doc/current/components/console.htmlsymfony http 客户端 https://symfony.com/doc/current/http_client.html 用于获取和使用 http apisymfony twig https://twig.symfony.com/doc/3.x/intro.html#installation 用于渲染数据菜谱api:我们将选择一个“虚拟”菜谱 https://dummyjson.com/recipes/1 来展示和演示检索结构化 json 并将其转换为 markdown 文件的过程.

安装必要的 symfony 组件

确保您已安装 http 请求和创建命令所需的组件:

composer require symfony/http-client symfony/console twig/twig

创建 symfony 命令

首先,让我们创建一个新的 symfony 命令。

立即学习“PHP免费学习笔记(深入)”;

如果您想了解有关如何使用 symfony command 组件创建命令行工具的更多信息,我写了一篇关于此的具体文章:https://dev.to/robertobutti/building-a-command-line-tool -with-php-and-symfony-console-4n6g

命令类,通常进入 src/commands 目录。

# create a new empty directorymkdir -p src/commands# create a new empty filetouch src/commands/fetchrecipecommand.php

命令类(例如,src/commands/fetchrecipecommand.php):

setname('recipe')            ->setdescription('prints a recipe in markdown')            ->sethelp('this command prints a simple recipe in markdown.');        // step 1: loading the twig environment        $loader = new wigloaderilesystemloader(__dir__ . '/../resources/views');        $twig = new wigenvironment(            $loader,            // optional: enable caching for better performance            /*[                'cache' => __dir__ . '/../../cache',            ]*/        );        $this->twig = $twig;        parent::__construct();    }    protected function configure()    {        $this->setdescription('fetches a recipe from an api and renders it as markdown');    }    protected function execute(inputinterface $input, outputinterface $output): int    {        // step 2: initialize the http client and fetch the recipe        $client = httpclient::create();        $response = $client->request('get', 'https://dummyjson.com/recipes/1');        // step 3: obtain the array of info        $recipedata = $response->toarray();        // step 4: render the template using twig, returning a string        $markdownoutput = $this->twig->render('recipe.md.twig', $recipedata);        // step 5: output the generated markdown        $output->writeln($markdownoutput);        return command::success;    }}

以下是 fetchrecipecommand 示例中每个步骤的详细说明。

逐步细分

第1步:加载twig环境

要在典型的 web 上下文之外使用 twig,例如在 php 命令行工具中,首先需要通过 twigenvironment 类手动初始化它。以下是控制台命令中 twig 设置的示例:

$loader = new wigloaderilesystemloader(__dir__ . '/../resources/views');$twig = new wigenvironment(    $loader,    // optional: enable caching for better performance    /*[        'cache' => __dir__ . '/../../cache',    ]*/);$this->twig = $twig;

说明:

twig 环境是通过创建一个 filesystemloader 来初始化的,该 filesystemloader 告诉 twig 在哪里可以找到模板。本例指向存储 twig 模板的 src/resources/views 文件夹。然后,$twig 环境被实例化并负责渲染模板。可以启用可选缓存,通过存储预编译模板来提高性能。最后将初始化的$twig环境赋值给$this->twig以供后续使用(在execute()方法中)。

第 2 步:初始化 http 客户端并获取配方

$client = httpclient::create();$response = $client->request('get', 'https://dummyjson.com/recipes/1');

说明:

symfony http 客户端是使用 httpclient::create() 方法创建的,该方法允许命令执行 http 请求。要获取菜谱,request() 方法会对指定的 url (https://dummyjson.com/recipes/1) 执行 get 请求。api 返回存储在 $response 变量中的 json 响应。

第三步:获取信息数组

$recipedata = $response->toarray();

说明:

toarray() 方法将 api 的 json 响应转换为 php 数组。该数组包含食谱的数据(例如名称、成分、说明),这些数据将用于在下一步中填充 twig 模板。

第四步:使用twig渲染模板

$markdownoutput = $this->twig->render('recipe.md.twig', $recipedata);

说明:

twig 环境的 render() 方法生成 markdown 输出。它从 src/resources/views 文件夹加载模板 (recipe.md.twig)。从 api 获取的菜谱数据 ($recipedata) 被传递到模板中,它将替换菜谱名称、成分和说明等占位符,创建一个完全格式化的 markdown 文件。渲染后的 markdown 内容(render() 方法返回的字符串)存储在 $markdownoutput 变量中。

第 5 步:为生成的 markdown 生成输出

$output->writeln($markdownoutput);

说明:

最终的 markdown 内容使用 $output->writeln() 方法打印到控制台。该方法将字符串输出到控制台,允许用户以 markdown 格式查看格式化的菜谱(最终,您可以将输出重定向到 shell 中的文件中)。

创建启动文件

您必须创建一个启动文件以允许用户直接从 shell 启动您的 symfony 命令。 (在本文中,我们不是创建 symfony 应用程序;我们正在使用 symfony 包构建 php 脚本。)
在项目目录中,您有composer.json文件和src目录,您可以创建一个my-app文件。

#!/usr/bin/env phpsetdefaultcommand("recipe");$app->add(new fetchrecipecommand());$app->run();

要正确使用命名空间和类,请务必在composer.json 文件中设置自动加载部分:

{    "require": {        "symfony/http-client": "^7.1",        "symfony/console": "^7.1",        "twig/twig": "^3.14"    },    "autoload": {        "psr-4": {            "myexample": "src/"        }    }}

如果您更改自动加载部分,我建议转储自动加载文件:

composer dump-autoload

现在,您必须创建 twig 模板/视图来呈现 api 检索到的数据。

为菜谱创建一个 twig 模板/视图

接下来,创建一个 twig 模板/视图以以 markdown 格式呈现配方。
该模板应位于视图目录中(例如 src/resources/view/recipe.md.twig)。

# recipe: {{ name }}- preparation time: {{ preptimeminutes }} minutes- cooking time {{ cooktimeminutes }} minutes- difficulty level: {{ difficulty }}- cuisine: {{ cuisine }}- servings {{ servings }} people, with {{ caloriesperserving }} calories per person## ingredients:{% for ingredient in ingredients %}- {{ ingredient }}{% endfor %}## instructions:{% for instruction in instructions %}- {{ instruction }}{% endfor %}enjoy!

此 twig 视图文件将以 markdown 格式呈现菜谱,其中包含菜谱名称、成分和说明部分。

运行命令

要执行该命令,请在终端中运行以下命令:

php my-app

如果您有多个命令,您可以启动:

php m-app recipe

要查看所有可用的命令:

php my-app list

结论

通过这种方法,您可以使用 symfony 的 http 客户端轻松地从外部 api 检索数据、处理响应并使用 twig 以结构化格式呈现输出。在本例中,该命令将配方输出为 markdown,但此技术可以适用于您需要处理的任何其他内容或数据类型。
享受你的食谱!

以上就是使用 Twig 通过 PHP 渲染 Markdown的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1248531.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月9日 20:35:21
下一篇 2025年12月9日 20:35:29

相关推荐

  • 如何在 4 中使用 Laravel Pennant 管理功能标志

    管理功能标志是现代软件开发的一个关键方面,它允许开发人员在不重新部署代码的情况下打开和关闭功能。在 laravel 中,可以使用 laravel 10 中引入的 laravel pennant 包来管理功能标志。 pennant 提供了一种简单有效的方法来管理功能标志,使您能够控制对新功能的访问、进…

    2025年12月9日
    000
  • 【Laravel vx Docker】利用 Laravel Sail 高效搭建 Laravel 应用开发环境

    关于 laravel sail laravel sail 是 laravel 框架的官方开发环境。 sail 提供了一个轻量级的命令行界面 (cli),可以使用 docker 轻松设置和管理 laravel 应用程序开发环境。下面,我们讲解一下 laravel sail 的主要特性和使用方法。 使用…

    2025年12月9日
    000
  • 授权:了解 Laravel 中的策略

    控制用户在应用程序中可以执行或不能执行的操作是构建实际应用程序时需要做的最重要的事情之一。 例如,在待办事项应用程序中,您不希望用户能够编辑或删除其他用户的待办事项。 在本文中,您将学习在 laravel 中实现此目的的无缝方法之一,即使用策略来控制用户可以通过构建简单的待办事项应用程序执行哪些操作…

    2025年12月9日
    000
  • 如何使用 Eloquent 计算多列的总和

    在本教程中,我将向您展示如何使用 eloquent 计算多列的总和。 laravel 提供了通过“sum”方法聚合列值的内置支持,允许您计算列值的总和。您可以学习如何使用 eloquent 计算列的平均值 这里的主要警告是 eloquent 一次只能对一列求和。要对 2 列求和,我们可以调用 sum…

    2025年12月9日
    000
  • 了解 PSR – PHP 编码风格指南

    如果您使用 php 进行开发已有一段时间,您可能遇到过术语 psr-12。它是 php 社区中最广泛接受的编码标准之一,旨在确保不同项目之间 php 代码库的一致性。无论您是单独工作还是作为团队的一员,遵循 psr-12 都可以使您的代码更干净、更具可读性并且更易于维护。在本博客中,我们将详细介绍 …

    2025年12月9日
    000
  • Laravel 自定义辅助函数 – 快速提示

    辅助函数在 laravel 开发者中非常流行。它们提供了对一些巧妙算法的访问,可以使用单个语句在您的代码中使用。 最知名的辅助函数可能是 url(),它允许您生成内部应用程序 url。 另一个很棒的帮手是 retry() 函数,例如:https://laravel.com/docs/11.x/hel…

    2025年12月9日
    000
  • Lithe 上的 PHP 会话管理:从基础配置到高级使用

    当我们谈论 web 应用程序时,首要需求之一是在用户浏览页面时维护用户的信息。这就是 lithe 中的 会话管理 的用武之地,它允许您存储登录信息或用户首选项等数据。 安装简单快捷 要开始在 lithe 中使用会话,您只需通过 composer 安装会话中间件。只需在项目中的终端中运行以下命令: c…

    2025年12月9日
    000
  • 使用 Lithe 进行 PHP 会话管理:从基本设置到高级使用

    当我们谈论 web 应用程序时,首要需求之一是在用户浏览页面时维护用户信息。这就是 lithe 中的 会话管理 的用武之地,它允许您存储登录信息或用户首选项等数据。 安装简单快捷 要开始在 lithe 中使用会话,您只需通过 composer 安装会话中间件。只需在项目中的终端中运行以下命令: co…

    2025年12月9日
    000
  • 发布开源包:真的值得吗?

    很多人喜欢说开源社区是现代发展的支柱。但对于普通开发者来说,投入时间和精力来发布 python 和 php 包真的值得吗?一些人认为,为了获得知名度和机会,任何困难都是值得的。其他人则认为这只是一种“昂贵的爱好”,与付出的努力相比,回报即使不是不存在,也是微乎其微的。 现实情况是,大多数为开源包做出…

    2025年12月9日
    000
  • php网络编程指南:HTTP协议入门

    PHP 网络编程指南:HTTP 协议入门 简介 HTTP(超文本传输协议)是一种客户端-服务器协议,用于在万维网上传输数据。它是 Web 的基础,让我们能够通过浏览器访问网站。本指南将介绍 HTTP 协议的基础知识,并通过代码示例展示如何在 PHP 中使用它。 HTTP 消息格式 立即学习“PHP免…

    2025年12月9日
    000
  • SharpAPI Laravel 集成指南

    欢迎来到sharpapi laravel 集成指南!该存储库提供了有关如何将 sharpapi 集成到下一个 laravel ai 应用程序中的全面的分步教程。无论您是希望通过**人工智能支持的功能**还是自动化工作流程来增强您的应用程序,本指南都将引导您完成从身份验证到进行 api 调用和处理响应…

    2025年12月9日
    000
  • php网络编程指南:WebSocket编程详解

    websocket 是一种允许客户端和服务器通过单个 tcp 连接进行全双工通信的协议。使用 php 开发 websocket 应用程序的步骤如下:安装 ratchet pawl 库。创建 websocket 服务器,使用 ratchet pawl 库并实现 websocket 应用程序类。实现 o…

    2025年12月9日
    000
  • php网络编程指南:使用cURL库进行HTTP请求

    php 网络编程中使用 curl 库发送 http 请求安装 curl 扩展。发送 get 请求:使用 curl_init()、curl_setopt() 和 curl_exec()。发送 post 请求:在 curl_setopt() 中设置 curlopt_post 为 true,并使用 cur…

    2025年12月9日
    000
  • 超越 AES — 使用 XChaCha20 对 Laravel 进行现代加密

    在当今的数字环境中,数据加密是每个 web 应用程序的重要组成部分。本文探讨了我为什么开发一个利用 libsodium 的 xchacha20-poly1305 加密功能的包,以及它如何增强 laravel 应用程序的安全性,同时最大限度地减少开销。 动机和要求 laravel 的框架 crypt …

    2025年12月9日
    000
  • php网络编程指南:RESTful API开发指南

    如何使用 laravel 创建 restful api?安装 laravel。配置路由,通过 routes/api.php 定义 crud 操作路由。创建控制器 todocontroller,用于处理 crud 操作。添加代码注释,以清楚地描述每个操作的功能。使用 postman 安装并调用 api…

    2025年12月9日
    000
  • 如何使用 Laravel 框架扩展 PHP 函数的日志记录?

    laravel 提供了一种方法来扩展 php 函数的日志记录:安装 monolog/monolog 扩展。在 config/logging.php 中配置 custom 日志通道。使用 illuminatesupportfacadeslog 门面记录自定义日志。 使用 Laravel 扩展 PHP …

    2025年12月9日
    000
  • php函数日志记录第三方模块问题解答

    第三方模块,如 monolog,可简化 php 程序日志记录。安装 monolog(composer require monolog/monolog)配置 monolog(创建 logger 并指定处理器)使用 info()、error() 等方法记录日志信息集成 psr-3 标准,便于在模块间切换…

    2025年12月9日
    000
  • 如何在 PHP 函数中使用日志记录上下文?

    如何在 PHP 函数中使用日志记录上下文 PHP 日志记录上下文允许您在日志记录消息中添加额外的附加信息,从而有助于调试和故障排除。 使用步骤 加载 Monolog 日志记录库:php composer require monolog/monolog 创建日志记录器:php $logger = ne…

    2025年12月9日
    000
  • 小型 Swoole 实体管理器

    我很高兴向大家介绍 Small Swoole Entity Manager。 它是一个围绕 Swoole(和 OpenSwoole)构建的 ORM。 它支持异步连接到: MySQLPostgres小型 Swoole Db(Swoole Tables 之上的关系层) 目前仅提供核心包; Symfony…

    2025年12月9日
    000
  • PHP 函数与 DevOps 实践的整合?

    通过以下方法整合 php 函数与 devops 实践,可以提高开发和运维流程的效率:自动化测试(例如,使用 phpunit)代码静态分析(例如,使用 phpstan)部署自动化(例如,使用 composer) PHP 函数与 DevOps 实践的整合 在 DevOps 的快节奏环境中,自动化和效率至…

    2025年12月9日
    000

发表回复

登录后才能评论
关注微信