Skip to content
Switch branches/tags

Latest commit

This was not required before because the code was
always processed in order. Take this template:

    <%= @text %>
    <%= Phoenix.LiveView.HTMLEngineTest.do_block do %><%= assigns[:not_text] %><% end %>

Using LiveEngine only, it will compile to this:

    arg0 = @text
    arg1 =
      Phoenix.LiveView.HTMLEngineTest.do_block do
        arg1 = assigns[:not_text]
        {:safe, arg1}
    {:safe, [arg0, arg1]}

However, the HTMLEngine changes the others the
expressions are processed. In particular, we
process the blocks first, then the root. So we
have this:

    arg0 = @text
    arg1 =
      Phoenix.LiveView.HTMLEngineTest.do_block do
        arg0 = assigns[:not_text]
        {:safe, arg0}
    {:safe, [arg0, arg1]}

If the do-block does not introduce a new scope
(i.e. it is not a macro), then arg0 inside the
block will override the external arg0. By
introducing depth, now we have:

    v0_0 = @text
    v0_1 =
      Phoenix.LiveView.HTMLEngineTest.do_block do
        v1_0 = assigns[:not_text]
        {:safe, v1_0}
    {:safe, [v0_0, v0_1]}

Fully addressing the conflict.

Git stats


Failed to load latest commit information.

Phoenix LiveView

Actions Status

Phoenix LiveView enables rich, real-time user experiences with server-rendered HTML.

After you install Elixir in your machine, you can create your first LiveView app in two steps:

$ mix archive.install hex phx_new
$ mix demo --live


  • Use a declarative model to render HTML on the server over WebSockets with optional LongPolling fallback

  • Smart templating and change tracking - after connected, LiveView sends only what changed to the client, skipping the template markup and reducing the payload

  • Live form validation with file upload support

  • A rich integration API with the client with phx-click, phx-focus, phx-blur, phx-submit, etc. phx-hook is included for the cases where you have to write JavaScript

  • Code reuse via components, which break templates, state, and event handling into reusable bits, which is essential in large applications

  • Live navigation to enrich links and redirects to only load the minimum amount of content as users navigate between pages

  • A latency simulator so you can emulate how slow clients will interact with your application

  • Testing tools that allow you to write a confident test suite without the complexity of running a whole browser alongside your tests

Official announcements

News from the Phoenix team on LiveView:


See our existing comprehensive docs and guides for more information.


There are currently two methods for installing LiveView. For projects that require more stability, it is recommended that you install using the installation guide on HexDocs. If you want to use the latest features, you should follow the instructions given in the markdown file here.

What makes LiveView unique?

LiveView is server centric. You no longer have to worry about managing both client and server to keep things in sync. LiveView automatically updates the client as changes happen on the server.

LiveView is first rendered statically as part of regular HTTP requests, which provides quick times for "First Meaningful Paint", in addition to helping search and indexing engines.

Then LiveView uses a persistent connection between client and server. This allows LiveView applications to react faster to user events as there is less work to be done and less data to be sent compared to stateless requests that have to authenticate, decode, load, and encode data on every request.

When LiveView was first announced, many developers from different backgrounds got inspired about the potential unlocked by LiveView to build rich, real-time user experiences. We believe LiveView is built on top of a solid foundation that makes LiveView hard to replicate anywhere else:

  • LiveView is built on top of the Elixir programming language and functional programming, which provides a great model for reasoning about your code and how your LiveView changes over time.

  • By building on top of a scalable platform, LiveView scales well vertically (from small to large instances) and horizontally (by adding more instances). This allows you to continue shipping features when more and more users join your application, instead of dealing with performance issues.

  • LiveView applications are distributed and real-time. A LiveView app can push events to users as those events happen anywhere in the system. Do you want to notify a user that their best friend just connected? This is easily done without a single-line of custom JavaScript and with no extra external dependencies (no extra databases, no extra message queues, etc).

  • LiveView performs change tracking: whenever you change a value on the server, LiveView will send to the client only the values that changed, drastically reducing the latency and the amount of data sent over the wire. This is achievable thanks to Elixir's immutability and its ability to treat code as data.

  • LiveView separates the static and dynamic parts of your templates. When you first render a page, Phoenix LiveView renders and sends the whole template to the browser. Then, for any new update, only the modified dynamic content is resent. This alongside diff tracking makes it so LiveView only sends a few bytes on every update, instead of sending kilobytes on every other user interaction - which would be detrimental to the user experience.

Browser Support

All current Chrome, Safari, Firefox, and MS Edge are supported. IE11 support is available with the following polyfills:

$ npm install --save --prefix assets mdn-polyfills url-search-params-polyfill formdata-polyfill child-replace-with-polyfill classlist-polyfill new-event-polyfill @webcomponents/template shim-keyboard-event-key core-js

Note: The shim-keyboard-event-key polyfill is also required for MS Edge 12-18.

// assets/js/app.js
import "mdn-polyfills/Object.assign"
import "mdn-polyfills/CustomEvent"
import "mdn-polyfills/String.prototype.startsWith"
import "mdn-polyfills/Array.from"
import "mdn-polyfills/Array.prototype.find"
import "mdn-polyfills/Array.prototype.some"
import "mdn-polyfills/NodeList.prototype.forEach"
import "mdn-polyfills/Element.prototype.closest"
import "mdn-polyfills/Element.prototype.matches"
import "mdn-polyfills/Node.prototype.remove"
import "child-replace-with-polyfill"
import "url-search-params-polyfill"
import "formdata-polyfill"
import "classlist-polyfill"
import "new-event-polyfill"
import "@webcomponents/template"
import "shim-keyboard-event-key"
import "core-js/features/set"
import "core-js/features/url"

import {Socket} from "phoenix"
import LiveSocket from "phoenix_live_view"


We appreciate any contribution to LiveView.

Please see the Phoenix Code of Conduct and Contributing guides.

Running the Elixir tests:

$ mix deps.get
$ mix test

Running the Javascript tests:

$ cd assets
$ npm run test
# to automatically run tests for files that have been changed
$ npm run

JS contributions are very welcome, but please do not include an updated priv/static/phoenix_live_view.js in pull requests. The maintainers will update it as part of the release process.