Redcarpet语法突出显示

Min*_*ohn 3 ruby syntax-highlighting ruby-on-rails redcarpet

我正试图通过Redcarpet工作来获得Syntax Highlighting

我的appliaction_helper.rb:

module ApplicationHelper

  def markdown(text)
    render_options = {
        # will remove from the output HTML tags inputted by user
        filter_html:     true,
        # will insert <br /> tags in paragraphs where are newlines
        hard_wrap:       true,
        # hash for extra link options, for example 'nofollow'
        link_attributes: { rel: 'nofollow' },
        # Prettify
        prettify:        true
    }
    renderer = Redcarpet::Render::HTML.new(render_options)

    extensions = {
        #will parse links without need of enclosing them
        autolink:           true,
        # blocks delimited with 3 ` or ~ will be considered as code block.
        # No need to indent.  You can provide language name too.
        # ```ruby
        # block of code
        # ```
        fenced_code_blocks: true,
        # will ignore standard require for empty lines surrounding HTML blocks
        lax_spacing:        true,
        # will not generate emphasis inside of words, for example no_emph_no
        no_intra_emphasis:  true,
        # will parse strikethrough from ~~, for example: ~~bad~~
        strikethrough:      true,
        # will parse superscript after ^, you can wrap superscript in ()
        superscript:        true
        # will require a space after # in defining headers
        # space_after_headers: true
    }
    Redcarpet::Markdown.new(renderer, extensions).render(text).html_safe
  end

end
Run Code Online (Sandbox Code Playgroud)

虽然输出显示在代码块(redcarpet)中:

在此输入图像描述

我找不到了Syntax Highlighting.

我刚进入Redcarpet,有人知道这个解决方案吗?

Min*_*ohn 9

好吧,我发现 - > 在Ruby on Rails中使用Markdown和代码语法突出显示(使用RedCarpet和CodeRay),它们非常有效(与Coderay的一些自定义css一起).

的Gemfile:

gem 'redcarpet', github: 'vmg/redcarpet'
gem 'coderay'
Run Code Online (Sandbox Code Playgroud)

Application_helper.rb

class CodeRayify < Redcarpet::Render::HTML
  def block_code(code, language)
    CodeRay.scan(code, language).div
  end
end

def markdown(text)
  coderayified = CodeRayify.new(:filter_html => true, 
                                :hard_wrap => true)
  options = {
    :fenced_code_blocks => true,
    :no_intra_emphasis => true,
    :autolink => true,
    :strikethrough => true,
    :lax_html_blocks => true,
    :superscript => true
  }
  markdown_to_html = Redcarpet::Markdown.new(coderayified, options)
  markdown_to_html.render(text).html_safe
end
Run Code Online (Sandbox Code Playgroud)

  • `def block_code(code,language)language || =:plaintext CodeRay.scan(code,language).div end` (3认同)

wpp*_*wpp 5

这是使用Rouge进行此操作的快速方法:

require 'redcarpet'
require 'rouge'
require 'rouge/plugins/redcarpet'

class HTML < Redcarpet::Render::HTML
  include Rouge::Plugins::Redcarpet # yep, that's it.
end
Run Code Online (Sandbox Code Playgroud)

当然,这需要rouge在您的Gemfile.