欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

Katana – 支持 Markdown 语法的 PHP 静态站点/博客生成器

程序员文章站 2022-03-29 13:59:08
...
目前已经有好几种静态站点生成器,如 Hexo、Jekyll等,今天发现一款使用 PHP 语法的静态博客生成器,支持 Markdown 语法,并且使用的是 Laravel 的 Blade 模版引擎。

Katana 的主要特点:

  • 支持 Markdown 语法
  • 快速安装
  • 自带 Pretty URLs
  • 简单的文章分页
  • 支持 Github Pages

一、安装

安装 Katana 非常简单,你只需运行 composer create-project命令:

composer create-project themsaid/katana your-site-name

现在你已经把 Katana 安装在了 your-site-name目录下,然后你需要运行下面的命令来生成站点:

cd your-site-namephp katana build

之后会在文件夹中生成一个 public 目录,里面就是生成的静态文件。

为 bulid 指定 baseURL

在生成静态文件时,可以通过 base_url来指定 baseUrl:

php katana build --base_url=/awesome-site

这样做的话,当你使用 Blade 的 @url()指令生成链接的时候会生成这样的 URLs: /awesome-site/about

二、目录结构

当运行 build命令后,会生成如下的文件结构:

  • content:这是 Katana 寻找你网站内容的地方
  • _cache:这是 Blade 保存编译完的视图文件的地方
  • public:Katana 会把生成的静态文件保存在这里
  • config.php:网站配置项

2.1 关于 “content”的目录结构

这个文件夹中保存的是你的 Blade 视图,静态文件(JS、CSS、图片等), _blog文件夹以及 _include文件夹。

_content文件夹是保存你 Blade 布局和基本视图的地方,Katana 不会为这些文件生成可访问的页面。

_blog文件夹是存放博客内容的地方。

2.2 关于 config.php

这个文件包含了 Katana 在生成静态文件是需要的一些预定义项,每一个配置项都有详细的说明,解释它们是用来做什么的。

你也可以在这个文件中定义任何变量,之后可以在网站的任何视图中调用该变量。

三、Blade 模版

如果你还不熟悉 Blade 模版的话,下面这段话是来自 Laravel 网站对它的介绍:

Blade 是一个由 Laravel 提供的简单但功能强大的模版引擎。同其他主流的 PHP 模版引擎不同的是,Blade 并不限制你在视图中使用纯 PHP 代码。

建议你到这里读一下 Blade 的文档。

3.1 在 Blade 中使用 Markdown 语法

Katana 为 Blade 添加了一个 @markdown指令,你可以这么使用它:

Regular HTML heading

@markdown This is some **Markdown** content.@endmarkdown

3.2 生成 URLs

Katana 使用 Blade 的 @url()指令为页面和静态文件生成 URLs,这些 URLs 会基于运行 build时指定的 base_url参数:

@('/')                // Outputs '/'@('about')            // Outputs '/about'@('assets/style.js')  // Outputs '/assets/style.js'

四、博客生成器

使用 Katana 来生成博客非常简单,你只需在 /content/_blog文件夹总创建一个文件,并遵循下面格式命名:

2016-03-03-my-post-slug.blade.php

文件名前的日期是用来在文件系统中对文件进行排序的,同时还用来生成博客的 URL,上面的文件会生成下面的 URL:

blog.com/my-post-slug-20160303

4.1 博客文章中的变量

博客的视图看起来应该是下面这样:

@section('post::title', 'Stop Trying To Be Somebody')@section('post::date', 'February 28, 2016')@section('post_body')    

@yield('post::title')

@yield('post::date') Post content here.@stop

以 post::开头的 Section 会添加到叫做 $blogPosts的全局变量中,这个变量可以在所有的视图中使用,并且它包含了文章对象的数组。

你可以使用这个变量来循环输出所有的博客文章:

@foreach($blogPosts as $blogPost)    
  • {{ $blogPost->title }} at {{ $blogPost->date }}
  • @endforeach

    path属性是 Katana 自动添加的,它保存的是文章的相对 URL。

    4.2 博客文章分页

    Katana 分页显示博客的文章,你需要先在 config.php中设置 postsPerPage和 postsListView配置项。浏览一下配置文件就会知道每一个配置项是做什么用的。

    在分页视图中, $paginatedBlogPosts变量包含了该页所有的文章,而 $nextPage和 $previousPage两个变量分别是后一页和前一页的链接。

    五、Github Pages

    你可以把站点部署到 Github Pages上,其想法是把 public目录作为你 Github Pages 库的主分支或者你其他库的 gh-pages分支。

    Step 1:把 Katana 添加到除 master/gh-pages 分支之外的其他分支

    我们这里把这个分支叫做 gh-pages-source,安装 Kanata 到该分支并按正常的步骤添加内容。

    Setp 2:生成站点

    当内容准备好之后就可以运行 build生成站点了:

    php katana build

    如果你不是使用的你的用户名的项目,则需要定义 base_url,如我的 Github 用户名为 9IPHP,但我没有把 Katana 发布到 9IPHP.github.com 这个项目,而是建立了一个 Katana 的项目,则需要这样生成站点:

    php katana build --base_url=/Katana

    Step 3:把文件 Push 到 Step 1 中建立的分支

    首先需要移除 .gitignore文件中的 public这一行,否则该目录是提交不上去的,之后运行如下命令:

    git add --allgit commit -m 'publishing website'git push origin gh-pages-source

    Step 4:把 public 目录添加到 master/gh-pages 分支

    git subtree push --prefix public origin master

    或者:

    git subtree push --prefix public origin gh-pages

    六、总结

    创建完成之后就可以到你的 Github Pages 中访问网站了,可以查看我创建的示例站点。

    项目 Github 地址