Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ruby/erb
An easy to use but powerful templating system for Ruby
https://github.com/ruby/erb
ruby
Last synced: 2 days ago
JSON representation
An easy to use but powerful templating system for Ruby
- Host: GitHub
- URL: https://github.com/ruby/erb
- Owner: ruby
- License: other
- Created: 2020-05-22T11:09:15.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-12-24T21:21:14.000Z (13 days ago)
- Last Synced: 2024-12-28T02:09:57.328Z (9 days ago)
- Topics: ruby
- Language: Ruby
- Homepage:
- Size: 307 KB
- Stars: 132
- Watchers: 32
- Forks: 16
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: COPYING
Awesome Lists containing this project
README
# ERB
An easy to use but powerful templating system for Ruby.
## Introduction
ERB provides an easy to use but powerful templating system for Ruby. Using
ERB, actual Ruby code can be added to any plain text document for the
purposes of generating document information details and/or flow control.A very simple example is this:
```rb
require 'erb'x = 42
template = ERB.new <<-EOF
The value of x is: <%= x %>
EOF
puts template.result(binding)
```Prints: `The value of x is: 42`
More complex examples are given below.
## Recognized Tags
ERB recognizes certain tags in the provided template and converts them based
on the rules below:```erb
<% Ruby code -- inline with output %>
<%= Ruby expression -- replace with result %>
<%# comment -- ignored -- useful in testing %> (`<% #` doesn't work. Don't use Ruby comments.)
% a line of Ruby code -- treated as <% line %> (optional -- see ERB.new)
%% replaced with % if first thing on a line and % processing is used
<%% or %%> -- replace with <% or %> respectively
```All other text is passed through ERB filtering unchanged.
## Options
There are several settings you can change when you use ERB:
* the nature of the tags that are recognized;
* the binding used to resolve local variables in the template.See the ERB.new and ERB#result methods for more detail.
## Character encodings
ERB (or Ruby code generated by ERB) returns a string in the same
character encoding as the input string. When the input string has
a magic comment, however, it returns a string in the encoding specified
by the magic comment.```rb
# -*- coding: utf-8 -*-
require 'erb'template = ERB.new <
__ENCODING__ is <%= __ENCODING__ %>.
EOF
puts template.result
```Prints: `__ENCODING__ is Big5.`
## Examples
### Plain Text
ERB is useful for any generic templating situation. Note that in this example, we use the
convenient "% at start of line" tag, and we quote the template literally with
`%q{...}` to avoid trouble with the backslash.```rb
require "erb"# Create template.
template = %q{
From: James Edward Gray II
To: <%= to %>
Subject: Addressing Needs<%= to[/\w+/] %>:
Just wanted to send a quick note assuring that your needs are being
addressed.I want you to know that my team will keep working on the issues,
especially:<%# ignore numerous minor requests -- focus on priorities %>
% priorities.each do |priority|
* <%= priority %>
% endThanks for your patience.
James Edward Gray II
}.gsub(/^ /, '')message = ERB.new(template, trim_mode: "%<>")
# Set up template data.
to = "Community Spokesman "
priorities = [ "Run Ruby Quiz",
"Document Modules",
"Answer Questions on Ruby Talk" ]# Produce result.
email = message.result
puts email
```Generates:
```
From: James Edward Gray II
To: Community Spokesman
Subject: Addressing NeedsCommunity:
Just wanted to send a quick note assuring that your needs are being addressed.
I want you to know that my team will keep working on the issues, especially:
* Run Ruby Quiz
* Document Modules
* Answer Questions on Ruby TalkThanks for your patience.
James Edward Gray II
```### Ruby in HTML
ERB is often used in .rhtml files (HTML with embedded Ruby). Notice the need in
this example to provide a special binding when the template is run, so that the instance
variables in the Product object can be resolved.```rb
require "erb"# Build template data class.
class Product
def initialize( code, name, desc, cost )
@code = code
@name = name
@desc = desc
@cost = cost@features = [ ]
enddef add_feature( feature )
@features << feature
end# Support templating of member data.
def get_binding
binding
end# ...
end# Create template.
template = %{
Ruby Toys -- <%= @name %>
<%= @name %> (<%= @code %>)
<%= @desc %>
- <%= f %>
<% @features.each do |f| %>
<% end %>
<% if @cost < 10 %>
Only <%= @cost %>!!!
<% else %>
Call for a price, today!
<% end %>
}.gsub(/^ /, '')
rhtml = ERB.new(template)
# Set up template data.
toy = Product.new( "TZ-1002",
"Rubysapien",
"Geek's Best Friend! Responds to Ruby commands...",
999.95 )
toy.add_feature("Listens for verbal commands in the Ruby language!")
toy.add_feature("Ignores Perl, Java, and all C variants.")
toy.add_feature("Karate-Chop Action!!!")
toy.add_feature("Matz signature on left leg.")
toy.add_feature("Gem studded eyes... Rubies, of course!")
# Produce result.
rhtml.run(toy.get_binding)
```
Generates (some blank lines removed):
```html
Ruby Toys -- Rubysapien
Rubysapien (TZ-1002)
Geek's Best Friend! Responds to Ruby commands...
- Listens for verbal commands in the Ruby language!
- Ignores Perl, Java, and all C variants.
- Karate-Chop Action!!!
- Matz signature on left leg.
- Gem studded eyes... Rubies, of course!
Call for a price, today!
```
## Notes
There are a variety of templating solutions available in various Ruby projects.
For example, RDoc, distributed with Ruby, uses its own template engine, which
can be reused elsewhere.
Other popular engines could be found in the corresponding
[Category](https://www.ruby-toolbox.com/categories/template_engines) of
The Ruby Toolbox.
## License
The gem is available as open source under the terms of the [2-Clause BSD License](https://opensource.org/licenses/BSD-2-Clause).