使用coderay和railscasts样式进行代码高亮 博客分类: Ruby RubyCSSRailsPythonDelphi
程序员文章站
2024-02-22 16:53:46
...
CodeRay是一个语法高亮的Ruby库,效率很不错。
CodeRay目前支持的语法包括:
railscasts的播主Ryan Bates自定义了一些css,让ruby、rhtml等代码看起来非常cool!
1,安装coderay gem
2,在application.rb中
3,在application_helper.rb里添加一个helper方法
这样,我们的文本输入框就支持这样的code标签了:
code:ruby这样的标签中ruby可以用上面提到的支持的语言来替代
4,借用railscasts的coderay样式
http://railscasts.com/stylesheets/coderay.css
5,在html.erb页面中
效果如下:
CodeRay目前支持的语法包括:
- Ruby
- C
- Delphi
- HTML
- RHTML (Rails)
- Nitro-XHTML
- YAML
- SQL
- Python
- Perl
- PHP
- Java
railscasts的播主Ryan Bates自定义了一些css,让ruby、rhtml等代码看起来非常cool!
1,安装coderay gem
gem install coderay
2,在application.rb中
require 'coderay'
3,在application_helper.rb里添加一个helper方法
def parse_coderay(text) text.scan(/(\[code\:([a-z].+?)\](.+?)\[\/code\])/m).each do |match| text.gsub!(match[0],CodeRay.scan(match[2].strip, match[1].to_sym).div( :line_numbers => :table,:css => :class)) end return text end
这样,我们的文本输入框就支持这样的code标签了:
\[code:ruby\] def aaa puts "aaaa" end \[\/code\]
code:ruby这样的标签中ruby可以用上面提到的支持的语言来替代
4,借用railscasts的coderay样式
http://railscasts.com/stylesheets/coderay.css
5,在html.erb页面中
<div class="CodeRay"><%= parse_coderay @post.content %></div>
效果如下: