在前端开发中,很多时候我们需要使用类似于 CMS (Content Management System,内容管理系统)的工具来管理网站或应用的内容。Netlify CMS 是一个非常流行的 CMS 工具,它支持 JAMstack 体系结构并且完全开源。@rrpm/netlify-cms-core 是 Netlify CMS 提供的一个核心包,它提供了许多强大且易于使用的功能,包括 Markdown 内容编辑器、自定义字段、集成 Git 等。本文将介绍如何使用 @rrpm/netlify-cms-core 创建一个简单的博客系统的实践案例。
环境准备
首先,为了更好地说明使用教程,我们需要准备好以下环境:
- Node.js:npm 包管理器和开发环境必备的软件。
- Github 账号:用于创建仓库并配置 Netlify CMS。
打开终端(或命令行)输入以下命令安装 @rrpm/netlify-cms-core:
npm install @rrpm/netlify-cms-core
创建仓库与配置 Netlify CMS
打开 Github,新建一个仓库,在仓库中新建一个配置文件 config.yml
,以下是最简单的配置内容:
backend: name: git-gateway branch: main # 分支名,可以替换为你自己的分支名
backend.name
说明你使用的是 git-gateway,这是 Netlify 提供的一种 Git 集成方式。backend.branch
说明指定使用哪个分支来存储内容数据,需要注意的是,这个分支必须存在且是非空的。
创建完成后,将 config.yml
提交到 Git 仓库中。以下是执行 Git 命令的示例代码:
git add config.yml git commit -m "Add config.yml" git push --set-upstream origin main
接下来,登录 Netlify 并创建一个新的网站,将刚才创建的 Github 仓库与 Netlify 网站绑定即可,具体配置过程可以参考 Netlify 官方文档。
使用 @rrpm/netlify-cms-core
现在,我们已经成功将网站与 Github 仓库和 Netlify CMS 集成了起来,接下来,我们要演示在网站中使用 @rrpm/netlify-cms-core 进行信息管理。
首先,我们需要创建一个 admin
目录。在这个目录下新建一个 config.yml
文件,这个文件与刚才在 Github 中创建的 config.yml
文件类似,都是用于配置 CMS 的参数。以下是示例代码:
-- -------------------- ---- ------- -------- ----- ----------- ------- ---- - ----- ------ ---- ------------- -------------------- -------------- ----------------- ------------ - ----- ------ - ---- ------ ------ - ------------ ------- -------------- - ------ ------- ---- - ------------ ----- ------------------------------------- - --- ---- ------- - --------- - - ------ ------- ----- -------- ------- -------- - - - ------ ------- ----- ------- ------- ---------- - - - ------ ------- ----- --------- ------- -------- - - - ------ ------- ----- -------- ------- ------- - - - ------ ------- ----- ------- ------- ---------- -
以上是配置文件的核心内容,其中 media_folder
和 public_folder
用于指定存储和查看图片的目录。collections
属性用于定义 CMS 中的集合(Collection),可以创建多个集合。每个集合都必须指定一个 name
属性,其它属性是可选的。slug
属性可以指定 URL 的生成规则,支持使用 Mustache 模板引擎。
以上的示例代码定义了一个名为 blog
的集合,用于管理博客文章的内容。这个集合包含一个 title
字段、一个 date
字段、一个 author
字段、一个 image
字段和一个 body
字段。其中,title
、date
、author
字段都是字符串类型,image
字段是图片类型,body
字段是 Markdown 类型。
接着,在 src
目录下创建一个 blog
目录,然后在 blog
目录下创建一个 Markdown 文件,用于存储和管理一篇博客文章的内容,以下是示例 Markdown
文件的内容:
--- title: "如何使用 @rrpm/netlify-cms-core" date: "2021-10-28T22:12:03.284Z" author: "Rena" image: "./image.png" --- 这是一个简单的博客文章,用于介绍如何使用 @rrpm/netlify-cms-core 创建博客网站。
其中,博客文章的头部使用了 YAML 格式,每个 YAML 属性之间通过换行符隔开。这个文件头部必须包含 title
、date
、author
和 image
四个属性,这些属性都与 collections.fields
中定义的博客文章字段相对应。
最后,运行以下命令启动 CMS 管理界面:
npx netlify-cms-proxy-server
访问 http://localhost:8080/admin/
,会看到一个供用户登录的界面,使用 Github 账户登录后,即可进入管理界面。
总结
通过本文,我们学习了如何使用 @rrpm/netlify-cms-core 创建一个简单的博客系统,包括如何创建 Git 仓库并与 Netlify CMS 集成,如何创建 config.yml
配置文件,以及如何使用 Markdown 编辑器和自定义字段来管理博客文章内容。总的来说,@rrpm/netlify-cms-core 提供了一个非常方便的 CMS 解决方案,值得开发者们去学习和使用。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/60066efe4c49986ca68d8b30