使用 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/1282408.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月10日 23:01:30
下一篇 2025年12月10日 23:01:40

相关推荐

  • 如何使用 Laravel 框架轻松整合微信支付与支付宝支付?

    如何通过 laravel 框架整合微信支付与支付宝支付 在 laravel 开发中,为电商网站或应用程序整合支付网关至关重要。其中,微信支付和支付宝是中国最流行的支付平台。本文将介绍如何使用 laravel 框架封装这两大支付平台。 一个简单有效的方法是使用业内认可的 easywechat lara…

    2025年12月24日
    000
  • Laravel 框架中如何无缝集成微信支付和支付宝支付?

    laravel 框架中微信支付和支付宝支付的封装 如何将微信支付和支付宝支付无缝集成到 laravel 框架中? 建议解决方案 考虑使用 easywechat 的 laravel 版本。easywechat 是一个成熟、维护良好的库,由腾讯官方人员开发,专为处理微信相关功能而设计。其 laravel…

    2025年12月24日
    500
  • 如何在 Laravel 框架中轻松集成微信支付和支付宝支付?

    如何用 laravel 框架集成微信支付和支付宝支付 问题:如何在 laravel 框架中集成微信支付和支付宝支付? 回答: 建议使用 easywechat 的 laravel 版,easywechat 是一个由腾讯工程师开发的高质量微信开放平台 sdk,已被广泛地应用于许多 laravel 项目中…

    2025年12月24日
    000
  • 使用Laravel框架如何整合微信支付和支付宝支付?

    使用 Laravel 框架整合微信支付和支付宝支付 在使用 Laravel 框架开发项目时,整合支付网关是常见的需求。对于微信支付和支付宝支付,推荐采用以下方法: 使用第三方库:EasyWeChat 的 Laravel 版本 建议直接使用现有的 EasyWeChat 的 Laravel 版本。该库由…

    2025年12月24日
    000
  • 如何将微信支付和支付宝支付无缝集成到 Laravel 框架中?

    如何简洁集成微信和支付宝支付到 Laravel 问题: 如何将微信支付和支付宝支付无缝集成到 Laravel 框架中? 答案: 强烈推荐使用流行的 Laravel 包 EasyWeChat,它由腾讯开发者维护。多年来,它一直保持更新,提供了一个稳定可靠的解决方案。 集成步骤: 安装 Laravel …

    2025年12月24日
    100
  • 利用Python和Dominate库自动化生成基于Excel数据的HTML文件

    本教程将指导您如何使用python编程语言,结合强大的dominate库,自动化地从excel数据生成结构化的html文件。通过解析excel中的每一行数据,并将其动态插入到预定义的html模板中,您可以高效地批量创建静态网页,极大地提升内容发布的效率。 在现代内容管理和网站开发中,经常需要将结构化…

    2025年12月23日
    200
  • 解决PHP环境中HTML与CSS资源(图片、样式)加载异常的常见问题

    在将html/css项目集成到php环境时,开发者常遇到图片和部分css样式(如背景图)无法正常加载的问题。这通常源于css文件链接方式不当或资源路径(包括“标签和css背景图)解析上下文的变化。本文将详细阐述正确的css引入方法、资源路径管理策略,并提供调试技巧,帮助您有效解决此类加载异常,确保…

    好文分享 2025年12月23日
    000
  • 利用Python Dominate实现Excel数据驱动的HTML文件批量创建

    本教程旨在指导如何使用python及其dominate库,自动化地从excel数据生成独立的html文件。文章将详细介绍如何通过编程方式构建html结构,并结合模拟的excel数据,实现每行数据对应一个html文件的批量创建,从而简化静态网站内容的管理与生成流程。 在现代Web开发中,尤其是在构建大…

    2025年12月23日
    200
  • Mac Valet一键站点,HTML+CSS开发环境王者!

    首先确认Valet服务已安装并运行,通过valet install和valet start初始化;使用valet park将项目目录设为可自动访问的本地根目录,新增项目即享.test域名;对独立项目可用valet link绑定自定义.test域名;为优化静态文件支持,在项目根目录创建.valet/s…

    2025年12月23日
    000
  • 使用Python自动化生成HTML文件:结合Excel数据与Dominate库

    本文将详细介绍如何利用python自动化生成html文件,特别适用于从excel等结构化数据源批量创建静态网页。我们将核心关注`dominate`库,一个用python代码直接构建html文档的强大工具,并结合实际需求,演示如何读取数据、动态生成内容,并输出为独立的html文件,从而实现高效的网页内…

    2025年12月23日 好文分享
    000
  • 使用Python自动化生成HTML文件并插入Excel数据

    本教程详细介绍了如何利用python的`dominate`库自动化创建html文件,并高效地将excel数据动态插入到这些文件中。文章将指导读者从环境搭建、基础html结构生成,到模拟excel数据读取,最终实现为每一行数据生成一个独立的、内容丰富的静态html页面。通过具体代码示例和专业指导,帮助…

    2025年12月23日 好文分享
    000
  • CommonMark中集成标签的扩展指南

    本教程将指导您如何在commonmark项目中利用`n0sz/commonmark-picture-extension`扩展,轻松实现对html5 “标签的支持。通过自定义的markdown语法,您可以为webp等现代图片格式提供jpg回退,确保在不同浏览器和设备上的最佳图片展示效果,从…

    2025年12月23日
    000
  • TYPO3网站集成翻译功能:从动态小部件到后端内容翻译的专业实践

    在TYPO3网站中实现多语言功能,提升用户体验和全球覆盖是常见需求。本文将深入探讨TYPO3网站翻译的两种主要方法:即时前端翻译小部件与后端内容翻译管理。我们将重点介绍如何利用如Deepl Translate等扩展,结合Google Translate等服务,实现高效、专业的后端内容翻译流程,并简要…

    2025年12月23日
    000
  • TYPO3 11网站多语言内容管理:集成Deepl与Google翻译扩展实践

    本文旨在探讨在typo3 11网站中实现高效多语言内容管理的策略。我们将重点介绍如何利用wv_deepltranslate扩展,将deepl和google翻译服务集成到typo3后台,实现内容元素和tca记录的自动化翻译,从而优化多语言网站的构建流程,提高内容生产效率和准确性,而非直接提供前端实时翻…

    2025年12月23日
    000
  • Web开发中Ruffle(Flash模拟器)代码注入的探究与应对

    在Web开发中,开发者工具中意外出现的Ruffle代码片段可能令人困惑。本文旨在解析这种代码注入现象,明确其作为Flash模拟器的功能,并指出其通常源于Ruffle库本身或其项目依赖。通过理解Ruffle的作用及其出现机制,开发者可以更好地识别、管理和排查相关问题,确保网页行为符合预期。 1. 引言…

    2025年12月22日
    000
  • HTML表单如何实现导出数据?怎样将表单数据保存为文件?

    HTML表单需结合JavaScript或服务器端脚本实现数据导出。1. 客户端可通过JavaScript读取表单数据,使用FormData获取输入值,将数据转换为CSV、JSON等格式,利用Blob和URL.createObjectURL创建下载链接,触发浏览器下载;示例代码展示了如何将表单数据导出…

    2025年12月22日
    000
  • 使用 PHP 发送包含表单答案的电子邮件

    本文档旨在指导开发者使用 PHP 处理 HTML 表单提交的数据,并将其通过电子邮件发送出去。我们将详细讲解如何配置表单的 action 属性,以及如何使用 PHP 代码接收、处理表单数据,并最终发送邮件。同时,也会介绍使用像 PHPMailer 这样的库来更安全、更便捷地发送邮件。 HTML 表单…

    2025年12月22日
    000
  • 使用 PHP 发送包含表单答案的邮件教程

    本文旨在帮助开发者使用 PHP 发送包含表单数据的电子邮件。我们将分析一个常见的表单提交问题,并提供修复方案,同时推荐使用 PHPMailer 等库来简化邮件发送过程,提升代码质量和安全性。 表单提交后 404 错误:路径问题 一个常见的问题是,在提交表单后,服务器返回 404 错误。这通常是由于表…

    2025年12月22日
    000
  • 使用 PHP 发送包含表单数据的电子邮件

    本文将指导您如何使用 PHP 处理 HTML 表单提交的数据,并通过电子邮件发送。我们将解决常见的 404 错误,并提供使用 PHP 内置 mail() 函数发送邮件的基本方法。此外,还会推荐使用更强大的 PHPMailer 库来发送邮件,并提供示例代码。 解决 404 错误:路径问题 首先,让我们…

    2025年12月22日
    000
  • 在Laravel框架中如何高效地集成微信支付和支付宝支付?

    在Laravel中高效集成微信支付和支付宝支付 构建现代互联网应用,集成第三方支付至关重要,尤其在中国市场,微信支付和支付宝是必备功能。本文介绍如何在Laravel框架中高效实现微信支付和支付宝支付集成。 推荐使用成熟可靠的社区库——EasyWeChat的Laravel版本。该库由腾讯工程师维护,历…

    2025年12月22日
    000

发表回复

登录后才能评论
关注微信