在本教學中,我們將在 Laravel 應用程式中建立輔助函數,以使用 league/commonmark 函式庫將 Markdown 內容轉換為 HTML。我們將介紹建立幫助程式檔案、將其包含在 Laravel 專案中以及在 Blade 範本中使用它的步驟。 Laravel 11 中使用了這個機制來使函數全域可用。
另一種方法是在將資料傳遞到視圖之前在控制器中處理 Markdown 轉換,因此我們不再需要建立輔助檔案:
use League\CommonMark\CommonMarkConverter; public function show($id) { $course = Course::find($id); $converter = new CommonMarkConverter(); $post->description = $converter->convertToHtml($post->description); return view('post.show', compact('post')); }
首先,我們透過 Composer 安裝 league/commonmark 函式庫:
composer require league/commonmark
接下來,我們將建立一個 helpers.php 檔案來定義我們的輔助函數。該檔案可以放置在應用程式目錄或任何其他首選位置。
touch app/helpers.php
開啟app/helpers.php並加入以下內容:
<?php use League\CommonMark\CommonMarkConverter; if (! function_exists('markdownToHtml')) { function markdownToHtml($markdown) { $converter = new CommonMarkConverter(); return $converter->convertToHtml($markdown); } }
為了確保Laravel自動載入helpers.php文件,我們需要修改composer.json文件,在autoload部分添加helpers.php的路徑:
"autoload": { "files": [ "app/helpers.php" ] }
修改composer.json後,透過執行以下指令重新產生Composer自動載入檔案:
composer dump-autoload
定義並載入輔助函數後,我們現在可以在 Blade 模板中使用它來將 Markdown 轉換為 HTML:
<div> {!! markdownToHtml($post->description) !!} </div>
本教學旨在展示我們如何在刀片模板中提供自訂功能。
以上是在 Laravel 11 中使用輔助函數將 Markdown 轉換為 HTML的詳細內容。更多資訊請關注PHP中文網其他相關文章!