Module: ERB::Util

Defined in:
lib/active_support/core_ext/string/output_safety.rb

Constant Summary collapse

HTML_ESCAPE =
{ '&' => '&amp;',  '>' => '&gt;',   '<' => '&lt;', '"' => '&quot;' }
JSON_ESCAPE =
{ '&' => '\u0026', '>' => '\u003E', '<' => '\u003C' }

Class Method Summary collapse

Class Method Details

.hObject

:nodoc:



41
42
43
44
45
46
47
48
# File 'lib/active_support/core_ext/string/output_safety.rb', line 41

def html_escape(s)
  s = s.to_s
  if s.html_safe?
    s
  else
    s.encode(s.encoding, :xml => :attr)[1...-1].html_safe
  end
end

.html_escape(s) ⇒ Object

:nodoc:



20
21
22
23
24
25
26
27
# File 'lib/active_support/core_ext/string/output_safety.rb', line 20

def html_escape(s)
  s = s.to_s
  if s.html_safe?
    s
  else
    s.encode(s.encoding, :xml => :attr)[1...-1].html_safe
  end
end

.jObject

A utility method for escaping HTML entities in JSON strings using uXXXX JavaScript escape sequences for string literals:

json_escape("is a > 0 & a < 10?")
# => is a \u003E 0 \u0026 a \u003C 10?

Note that after this operation is performed the output is not valid JSON. In particular double quotes are removed:

json_escape('{"name":"john","created_at":"2010-04-28T01:39:31Z","id":1}')
# => {name:john,created_at:2010-04-28T01:39:31Z,id:1}

This method is also aliased as j, and available as a helper in Rails templates:

<%=j @person.to_json %>


70
71
72
73
# File 'lib/active_support/core_ext/string/output_safety.rb', line 70

def json_escape(s)
  result = s.to_s.gsub(/[&"><]/) { |special| JSON_ESCAPE[special] }
  s.html_safe? ? result.html_safe : result
end

.json_escape(s) ⇒ Object

A utility method for escaping HTML entities in JSON strings using uXXXX JavaScript escape sequences for string literals:

json_escape("is a > 0 & a < 10?")
# => is a \u003E 0 \u0026 a \u003C 10?

Note that after this operation is performed the output is not valid JSON. In particular double quotes are removed:

json_escape('{"name":"john","created_at":"2010-04-28T01:39:31Z","id":1}')
# => {name:john,created_at:2010-04-28T01:39:31Z,id:1}

This method is also aliased as j, and available as a helper in Rails templates:

<%=j @person.to_json %>


65
66
67
68
# File 'lib/active_support/core_ext/string/output_safety.rb', line 65

def json_escape(s)
  result = s.to_s.gsub(/[&"><]/) { |special| JSON_ESCAPE[special] }
  s.html_safe? ? result.html_safe : result
end