實現(xiàn) Markdown 語法和代碼語法高亮分別是用的 Redcarpet 和 pygments.rb 兩個 Gem:
https://github.com/vmg/redcarpet
https://github.com/tmm1/pygments.rb
https://github.com/richleland/pygments-css
http://pygments.org/docs/lexers/
在/Gemfile中添加如下兩行:
gem 'redcarpet'
gem 'pygments.rb'
需要說明的是,pygments.rb 依賴于 Python,所以確保機器已經(jīng)安裝了 Python 2.x。
然后在/app/controllers/comments_controller.rb中添加相應 redcarpet 和 pygments.rb 的代碼:
class ApplicationController ActionController::Base
# Prevent CSRF attacks by raising an exception.
# For APIs, you may want to use :null_session instead.
protect_from_forgery with: :exception
helper_method [:markdown]
# Highlight code with Pygments
class HTMLwithPygments Redcarpet::Render::HTML
def block_code(code, language)
language = "text" if language.blank?
sha = Digest::SHA1.hexdigest(code)
Rails.cache.fetch ["code", language, sha].join("-") do
Pygments.highlight(code, :lexer => language)
end
end
end
protected
# Markdown with Redcarpet
def markdown(text)
renderer = HTMLwithPygments.new({
:filter_html => true,
:hard_wrap => true,
:link_attributes => {:rel => 'external nofollow'}
})
options = {
:autolink => true,
:no_intra_emphasis => true,
:fenced_code_blocks => true,
:lax_html_blocks => true,
:strikethrough => true,
:superscript => true,
:tables => true
}
Redcarpet::Markdown.new(renderer, options).render(text).html_safe
end
end
最后在 View 中就可以直接調(diào)用 markdown 方法來處理博客正文了:
%= markdown @post.content %>
語法規(guī)則類似 Github 上的 Markdown,碼字效率大大提高。
您可能感興趣的文章:- python 自動化將markdown文件轉(zhuǎn)成html文件的方法
- 獻給寫作者的 Markdown 新手指南
- 可能是最通俗的一篇介紹markdown的文章
- 玩轉(zhuǎn)markdown 分享幾個需要用到的工具
- Markdown+Bootstrap圖片自適應屬性詳解
- Markdown與Bootstrap相結(jié)合實現(xiàn)圖片自適應屬性
- 使用Python來開發(fā)Markdown腳本擴展的實例分享
- 如何使用Gitblog和Markdown建自己的博客
- Markdown語法備忘
- markdown簡介和語法介紹
- js驗證手機號碼