首页
/ Brochure 技术文档

Brochure 技术文档

2024-12-20 19:33:09作者:邵娇湘

1. 安装指南

首先,确保您的系统中已经安装了 Ruby 环境。接下来,通过以下命令安装 Brochure:

$ gem install brochure

Brochure 依赖于 Hike、Rack 和 Tilt,因此请确保这些库也已安装。

2. 项目使用说明

Brochure 是一个基于 Rack 的应用,用于提供静态网站服务,并支持 ERB 模板(或其他 Tilt 支持的模板语言)。以下是一个典型的应用结构示例:

templates/
  help/
    index.html.erb
  index.html.erb
  shared/
    _header.html.erb
    _footer.html.erb
  signup.html.erb
config.ru
public/
  ...

config.ru 文件中,您可以配置 Brochure:

require "brochure"
root = File.dirname(__FILE__)
run Brochure.app(root)

Brochure 会自动将 URL 映射到模板名称:

  • / 映射到 templates/index.html.erb
  • /signup 映射到 templates/signup.html.erb
  • /help/ 映射到 templates/help/index.html.erb

3. 项目API使用文档

Partials 和 helpers

模板可以渲染 Partials。Partials 以下划线开头的文件名标识。例如,<%= render "shared/header" %> 会渲染 templates/shared/_header.html.erb

Partials 可以通过 <%= yield %> 回到渲染它们的模板。这种方法可以用来将常见的头部和尾部标记提取到一个布局文件中。

模板可以通过 env 方法访问 Rack 环境,通过 application 方法访问 Brochure 应用程序。此外,还提供了一个围绕 Rack 环境的 Rack::Request 封装,可通过 request 方法访问。

您可以使用 h 辅助方法在模板中输出 HTML 转义字符串。

自定义辅助方法和实例变量

您可以将额外的辅助方法和实例变量添加到模板中。辅助方法位于 Ruby 模块中,可以通过 :helpers 选项包含到 Brochure.app 中:

module AssetHelper
  def asset_path(filename)
    local_path = File.join(application.asset_root, filename)
    digest = Digest::MD5.hexdigest(IO.read(local_path))
    "/#{filename}?#{digest}"
  end
end

run Brochure.app(root, :helpers => [AssetHelper])

类似地,实例变量可以通过 :assigns 选项定义:

run Brochure.app(root, :assigns => { :domain => "37signals.com" })

Tilt 模板选项

您可以为每个引擎指定全局 Tilt 模板选项,使用 :template_options

run Brochure.app(root, :template_options => {
  ".haml" => { :format => :html5 },
  ".md"   => { :smart  => true }
})

4. 项目安装方式

请参考“安装指南”部分,使用 Ruby gem 命令安装 Brochure。

登录后查看全文
热门项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
24
6
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
269
2.54 K
flutter_flutterflutter_flutter
暂无简介
Dart
558
124
fountainfountain
一个用于服务器应用开发的综合工具库。 - 零配置文件 - 环境变量和命令行参数配置 - 约定优于配置 - 深刻利用仓颉语言特性 - 只需要开发动态链接库,fboot负责加载、初始化并运行。
Cangjie
57
11
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
9
1
cangjie_runtimecangjie_runtime
仓颉编程语言运行时与标准库。
Cangjie
126
104
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
357
1.84 K
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.02 K
434
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.03 K
605
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
728
70