Phoenix.HTML (Phoenix.HTML v3.2.0) View Source
Helpers for working with HTML strings and templates.
When used, it imports the given modules:
Phoenix.HTML
- functions to handle HTML safety;Phoenix.HTML.Tag
- functions for generating HTML tags;Phoenix.HTML.Form
- functions for working with forms;Phoenix.HTML.Link
- functions for generating links and urls;Phoenix.HTML.Format
- functions for formatting text;
HTML Safe
One of the main responsibilities of this module is to provide convenience functions for escaping and marking HTML code as safe.
By default, data output in templates is not considered safe:
<%= "<hello>" %>
will be shown as:
<hello>
User data or data coming from the database is almost never considered safe. However, in some cases, you may want to tag it as safe and show its "raw" contents:
<%= raw "<hello>" %>
Keep in mind most helpers will automatically escape your data and return safe content:
<%= content_tag :p, "<hello>" %>
will properly output:
<p><hello></p>
JavaScript library
This project ships with a tiny bit of JavaScript that listens to all click events to:
Support
data-confirm="message"
attributes, which shows a confirmation modal with the given messageSupport
data-method="patch|post|put|delete"
attributes, which sends the current click as a PATCH/POST/PUT/DELETE HTTP request. You will need to adddata-to
with the URL anddata-csrf
with the CSRF token valueDispatch a "phoenix.link.click" event. You can listen to this event to customize the behaviour above. Returning false from this event will disable
data-method
. Stopping propagation will disabledata-confirm
Link to this section Summary
Functions
Escapes an enumerable of attributes, returning iodata.
Escapes the HTML entities in the given term, returning safe iodata.
Escapes HTML content to be inserted a JavaScript string.
Marks the given content as raw.
Converts a safe result into a string.
Link to this section Types
Specs
safe() :: {:safe, iodata()}
Guaranteed to be safe
Specs
unsafe() :: Phoenix.HTML.Safe.t()
May be safe or unsafe (i.e. it needs to be converted)
Link to this section Functions
Escapes an enumerable of attributes, returning iodata.
The attributes are rendered in the given order. Note if a map is given, the key ordering is not guaranteed.
The keys and values can be of any shape, as long as they
implement the Phoenix.HTML.Safe
protocol. In addition,
if the key is an atom, it will be "dasherized". In other
words, :phx_value_id
will be converted to phx-value-id
.
Furthemore, the following attributes provide behaviour:
:aria
,:data
, and:phx
- they accept a keyword list as value.data: [confirm: "are you sure?"]
is converted todata-confirm="are you sure?"
.:class
- it accepts a list of classes as argument. Each element in the list is separated by space.nil
andfalse
elements are discarded.class: ["foo", nil, "bar"]
then becomesclass="foo bar"
.:id
- it is validated raise if a number is given as ID, which is not allowed by the HTML spec and leads to unpredictable behaviour.
Examples
iex> safe_to_string attributes_escape(title: "the title", id: "the id", selected: true)
" title=\"the title\" id=\"the id\" selected"
iex> safe_to_string attributes_escape(%{data: [confirm: "Are you sure?"], class: "foo"})
" class=\"foo\" data-confirm=\"Are you sure?\""
iex> safe_to_string attributes_escape(%{phx: [value: [foo: "bar"]], class: "foo"})
" class=\"foo\" phx-value-foo=\"bar\""
Specs
Escapes the HTML entities in the given term, returning safe iodata.
iex> html_escape("<hello>")
{:safe, [[[] | "<"], "hello" | ">"]}
iex> html_escape('<hello>')
{:safe, ["<", 104, 101, 108, 108, 111, ">"]}
iex> html_escape(1)
{:safe, "1"}
iex> html_escape({:safe, "<hello>"})
{:safe, "<hello>"}
Specs
Escapes HTML content to be inserted a JavaScript string.
This function is useful in JavaScript responses when there is a need to escape HTML rendered from other templates, like in the following:
$("#container").append("<%= javascript_escape(render("post.html", post: @post)) %>");
It escapes quotes (double and single), double backslashes and others.
Specs
Marks the given content as raw.
This means any HTML code inside the given string won't be escaped.
iex> raw("<hello>")
{:safe, "<hello>"}
iex> raw({:safe, "<hello>"})
{:safe, "<hello>"}
iex> raw(nil)
{:safe, ""}
Specs
Converts a safe result into a string.
Fails if the result is not safe. In such cases, you can
invoke html_escape/1
or raw/1
accordingly before.
You can combine html_escape/1
and safe_to_string/1
to convert a data structure to a escaped string:
data |> html_escape() |> safe_to_string()