46

Jekyllブログに表示したいMarkdown形式のサイドバーがあります。私は以前のようにそれを含めようとしました{% include sidebar.markdown %}が、実際にはマークダウンをレンダリングしませんでした。私はそれを次のようにうまく含めることができます:

{% capture sidebar %}{% include sidebar.markdown %}{% endcapture %}
{{ sidebar | markdownify }}

これは管理しやすいソリューションですが、これを実現するためのよりエレガントな方法をお勧めします。何か案は?前もって感謝します!

4

2 に答える 2

21

私もこれを探していました、それはそれを行う方法を発見するPITAであり、Googleのコンテンツはあまりありませんでした。最も正確な発見は、ここでは機能しない要点でした...非常に単純な解決策:

./_plugins/markdown_tag.rb:

module Jekyll
  class MarkdownTag < Liquid::Tag
    def initialize(tag_name, text, tokens)
      super
      @text = text.strip
    end
    require "kramdown"
    def render(context)
      tmpl = File.read File.join Dir.pwd, "_includes", @text
      Jekyll::Converters::Markdown::KramdownParser.new(Jekyll.configuration()).convert(tmpl)
    end
  end
end
Liquid::Template.register_tag('markdown', Jekyll::MarkdownTag)

更新: 使用例のブログ: https://web.archive.org/web/20161207125751/http://wolfslittlestore.be/2013/10/rendering-markdown-in-jekyll/

于 2013-01-09T22:05:18.103 に答える
5

Jekyll は、タグ、コンバーター、またはジェネレーターを追加するための単純なプラグインの作成をサポートするようになりました。詳細については、http://jekyllrb.com/docs/plugins/をご覧ください。

于 2011-09-17T15:34:26.150 に答える