[data:image/s3,"s3://crabby-images/32341/323416a8dd1e6f2e557d8e67cecc7ea655316ac8" alt="Lines of Code"](http://blog.codinghorror.com/the-best-code-is-no-code-at-all/) [data:image/s3,"s3://crabby-images/054ad/054ada670c9afab3123e9e7c968507cdc60f9f75" alt="Maintainability"](https://codeclimate.com/github/hopsoft/stimulus_reflex/maintainability) # StimulusReflex ### Build reactive [Single Page Applications (SPAs)](https://en.wikipedia.org/wiki/Single-page_application) with [Rails](https://rubyonrails.org) and [Stimulus](https://stimulusjs.org) This project supports building [reactive applications](https://en.wikipedia.org/wiki/Reactive_programming) with the Rails tooling you already know and love. It's designed to work perfectly with [server rendered HTML](https://guides.rubyonrails.org/action_view_overview.html), [Russian doll caching](https://edgeguides.rubyonrails.org/caching_with_rails.html#russian-doll-caching), [Stimulus](https://stimulusjs.org), [Turbolinks](https://www.youtube.com/watch?v=SWEts0rlezA), etc... __No need for a complex front-end framework. No need to grow your team or duplicate your efforts.__ --- > The lifecycle of a "modern" SPA app is so convoluted, it requires a team to build and support. > The wire size and computation demands of these heavy client sites frequently run slower than the server-rendered pages that they replaced. > With Stimulus Reflex, a Rails developer can build Single Page Applications without the need for client rendering or heavy JS frameworks. --- _Inspired by [Phoenix LiveView](https://youtu.be/Z2DU0qLfPIY?t=670)._ 🙌 ## How it Works 1. Render a standard Rails view template 1. Use [Stimulus](https://stimulusjs.org) and [ActionCable](https://edgeguides.rubyonrails.org/action_cable_overview.html) to invoke a method on the server 1. Watch the page automatically render updates via fast [DOM diffing](https://github.com/patrick-steele-idem/morphdom) 1. That's it... __Yes, it really is that simple.__ There are no hidden gotchas. data:image/s3,"s3://crabby-images/e60c3/e60c3d7cf4cb744600828d038a3c4e54fc98d8f2" alt="How it Works" ## Setup ### JavaScript ``` yarn add stimulus_reflex ``` ### Gemfile ```ruby gem "stimulus_reflex" ``` ## Basic Usage ### app/views/pages/example.html.erb ```erb
Increment <%= @count.to_i %>