推荐开源项目:reading_time — 智能阅读时间估计器
在信息爆炸的时代,估算一篇文章的阅读时间成为了提升用户体验的关键。这便是reading_time的作用所在。这是一个基于Liquid模板语言的过滤器插件,能够智能地计算HTML文本中的单词数量,并预测阅读完整篇文章所需的时间。
安装与使用
安装reading_time
非常简单,只需要通过RubyGems运行命令gem install liquid_reading_time
。如果你正在使用Jekyll,可参照Jekyll文档来安装插件。这个插件依赖于Nokogiri,因此手动安装时别忘了添加这个依赖。
在实际使用中,你可以利用两个提供的函数:
-
reading_time
这个函数会返回一个整数,表示阅读输入文本所需的分钟数。例如,在Jekyll的布局文件中,可以这样使用:{% capture time %}{{ content | reading_time }}{% endcapture %} <p>这篇文章大约需要{{ time }}分钟阅读。</p>
结合pluralize过滤器,还可以处理单复数形式:
<p>这篇文章大约需要{{ content | reading_time | pluralize: "分钟" }}阅读。</p>
-
count_words
此函数则返回输入文本中的单词总数,同样接受HTML作为输入。
精准计时与智能忽略
reading_time
和count_words
都试图以最聪明的方式计算单词。它们不会在以下HTML元素内部计数:area, audio, canvas, code, embed, footer, form, img, map, math, nav, object, pre, script, svg, table, track, 和 video。这种设计旨在避免那些非正文部分的词汇影响到总数。
该插件默认的阅读速度为每分钟270个单词,这个值基于一般人的阅读速率。
作者与版本历史
该项目由Benjamin Esham创建,并托管在GitHub上,欢迎提交Pull Request。
版本更新
- v1.1.3 (2017-07-19): 更新了依赖,表明插件兼容Liquid 4。
- v1.1.2 (2015-03-07): 改进了单词分割规则,增加了单元测试,并支持Liquid 3.x。
- 更多版本信息,请参考项目仓库的历史记录。
许可证
reading_time
遵循ISC许可证,详细信息可在LICENSE.md文件中查看。
总之,无论你是个人博客作者还是企业网站开发者,reading_time
都是一个值得采用的工具,它将帮助你的读者更好地管理他们的时间,提高他们的浏览体验。现在就尝试集成并享受更智能的阅读统计吧!