<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0">
  <channel>
    <title>AlexKie (於杰)</title>
    <link>https://ruby-china.org/AlexKie</link>
    <description/>
    <language>en-us</language>
    <item>
      <title>代码高亮 以及每一行都有一个行号</title>
      <description>&lt;p&gt;我想在我的 rails app 里面展示一段代码，因此找了一次插件，比如 hightlight，coderay，syntaxhighter, prettify 等等，然后结合 redcarpet 使用。在实现代码高亮的这个问题上都没有问题，
但是现在的问题是我想为这些代码添加行号，而上面说的几个插件在展示行号的是将行号和代码内容进行了左右分区，也就是说，所有的代码都是在一个一个的&lt;span&gt;里面，代码的那一块没有区分行的标志，&lt;/span&gt;&lt;/p&gt;

&lt;p&gt;我找到几个是 html 代码是这样的&lt;/p&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;&amp;lt;div class="code"&amp;gt;
    &amp;lt;div class="linenum"&amp;gt;
        &amp;lt;span&amp;gt;1&amp;lt;/span&amp;gt;
         ......   #  这一块都是行号
        &amp;lt;span&amp;gt;n&amp;lt;/span&amp;gt;
    &amp;lt;/div&amp;gt;
    &amp;lt;div class="highlight"&amp;gt;
        &amp;lt;span&amp;gt;def&amp;lt;/span&amp;gt; 
        ......    #这里是   所有的代码按照语言进行高亮
        &amp;lt;span&amp;gt;end&amp;lt;/span&amp;gt;
    &amp;lt;/div&amp;gt;
&amp;lt;/div&amp;gt;
&lt;/code&gt;&lt;/pre&gt;
&lt;p&gt;但是我想要的是这样的的几个都是这样的&lt;/p&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;&amp;lt;div class="code"&amp;gt;
    &amp;lt;div id="linenum_1"&amp;gt;
        &amp;lt;a href="#linenum_1"&amp;gt;1&amp;lt;/a&amp;gt; #这里显示行号
        &amp;lt;div class='highlight'&amp;gt;
            &amp;lt;span&amp;gt;def &amp;lt;/span&amp;gt;
            .....              #这里指展示这一行的代码
            &amp;lt;span&amp;gt;end&amp;lt;/span&amp;gt;
        &amp;lt;/div&amp;gt;
    &amp;lt;/div&amp;gt;

    .....

    &amp;lt;div id="linenum_n"&amp;gt;
        &amp;lt;a href="#linenum_n"&amp;gt;n&amp;lt;/a&amp;gt; #这里显示行号
        &amp;lt;div class='highlight'&amp;gt;
            &amp;lt;span&amp;gt;def &amp;lt;/span&amp;gt;
            .....              #这里指展示这一行的代码
            &amp;lt;span&amp;gt;end&amp;lt;/span&amp;gt;
        &amp;lt;/div&amp;gt;
    &amp;lt;/div&amp;gt;
&amp;lt;/div&amp;gt;
&lt;/code&gt;&lt;/pre&gt;
&lt;p&gt;然后我看到了 rouge 这个插件，看到他的 readme 里面这样写&lt;/p&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;Rouge::Formatters::HTMLLinewise.new(formatter, class_format: 'line-%i') This formatter will split your code into lines, each contained in its own div. The class_format option will be used to add a class name to the div, given the line number.

&lt;/code&gt;&lt;/pre&gt;
&lt;p&gt;那么这个 formatter 应该如何构造呢？
谢谢大家了&lt;/p&gt;</description>
      <author>AlexKie</author>
      <pubDate>Sat, 01 Jul 2017 15:40:22 +0800</pubDate>
      <link>https://ruby-china.org/topics/33376</link>
      <guid>https://ruby-china.org/topics/33376</guid>
    </item>
  </channel>
</rss>
