首页
/ AutoHtml 技术文档

AutoHtml 技术文档

2024-12-23 00:27:56作者:冯梦姬Eddie

本文档将详细介绍如何安装、使用以及通过API操作AutoHtml项目。AutoHtml是一个将纯文本转换为HTML代码的过滤器集合。

1. 安装指南

要使用AutoHtml,您可以通过以下任一方式将其添加到您的Ruby应用程序中:

通过Gemfile安装

在您的应用程序的Gemfile中添加以下行:

gem 'auto_html'

然后执行以下命令:

$ bundle

手动安装

或者,您可以手动安装它:

$ gem install auto_html

2. 项目使用说明

AutoHtml采用了“管道和过滤器”处理设计模式的概念:

  • 过滤器(Filter) - 转换输入。在AutoHtml的上下文中,这是任何通过#call(String)方法执行转换的对象。过滤器选项应在初始化器中传递。AutoHtml已经提供了一些过滤器,例如链接(Link)、图像(Image)、Markdown等。

  • 管道(Pipeline) - 过滤器的组合,通过将一个过滤器的输出作为下一个过滤器的输入来转换输入。在AutoHtml的上下文中,这是AutoHtml::Pipeline类。由于同样的接口(方法#call)用于传递输入,我们可以说管道本身也是一个过滤器,这意味着它可以用作其他管道的构建块,与其他过滤器混合使用。

以下是一些使用示例:

link_filter = AutoHtml::Link.new(target: '_blank')
link_filter.call('查看我的博客: http://rors.org')
# 输出: '查看我的博客: <a target="blank" href="http://rors.org">http://rors.org</a>'

emoji_filter = AutoHtml::Emoji.new
emoji_filter.call(':point_left: 嘿!')
# 输出: '<img src="/images/emoji/unicode/1f448.png" class="emoji" title=":point_left:" alt=":point_left:" height="20" witdh="20" align="absmiddle" /> 嘿!'

# 使用管道组合过滤器
base_format = AutoHtml::Pipeline.new(link_filter, emoji_filter)
base_format.call('查看我的博客: http://rors.org :point_left: 嘿!')
# 输出: '查看我的博客: <a href="http://rors.org">http://rors.org</a> <img src="/images/emoji/unicode/1f448.png" class="emoji" title=":point_left:" alt=":point_left:" height="20" witdh="20" align="absmiddle" /> 嘿!'

3. 项目API使用文档

AutoHtml提供了以下内置过滤器:

  • AutoHtml::Emoji
  • AutoHtml::HtmlEscape
  • AutoHtml::Image,其中proxyalt是可选参数
  • AutoHtml::Link,其中targetrel是可选参数
  • AutoHtml::Markdown
  • AutoHtml::SimpleFormat

您可以根据需要创建新的过滤器并将其添加到管道中。

4. 项目安装方式

请参考上文提到的通过Gemfile或手动安装的方式。


以上文档提供了AutoHtml的基本安装和使用说明,以及如何通过API进行操作。通过这些信息,用户应能够开始使用AutoHtml并将其集成到自己的项目中。

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

热门内容推荐

最新内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
178
262
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
867
513
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
183
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
265
305
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
371
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
598
57
GitNextGitNext
基于可以运行在OpenHarmony的git,提供git客户端操作能力
ArkTS
10
3