Ruby-on-Rails and SvelteJS tutorial
Posted October 17, 2022 - tagged ruby-on-rails
7 min read
SvelteJS vs others
Svelte is the new paradigm of frameworks. Since it came to life in 2016, developers have argued a lot about it and compared it to its big brothers: React, Angular and Vue. In this article, we will deep dive into how this new framework works, its benefits and how to implement it with Ruby-on-Rails.
What is SvelteJS ?
Svelte is a framework without being a framework. And... What does this mean? In short, it means that Svelte is a compiler itself. To understand this concept, we are going to try to put it as simply as possible.
Frameworks are responsible for taking the code of an application and executing a set of tasks so that users can interact with it in the browser. As you might already know, the code is built into components (HTML, CSS and JS), which are translated into a virtual DOM, compared with the previous DOM and then updated to the Browser DOM. All this, by using techniques such as the Reconciliation and Diffing Algorithm.
To wrap up the characteristics of this technology and understand why you should consider it as a developer, let's take a look at its main advantages and disadvantages:
Svelte : advantages
- It has the smallest and fastest bundles. The Svelte bundle size is 1.6KB while React is 42.2KB.
- It has proved a very good performance and reactivity.
- Svelte is easy to learn and implement.
Svelte : disadvantages
- Technology is still evolving and it has a smaller community.
- It has a young library ecosystem.
- Implementation means learning a new language and syntax logic. And consequently, there are fewer developers using it for now.
Why combine both Rails and Svelte ?
Combining Svelte with Rails can be a great choice. Svelte simplifies code and makes it more efficient. Svelte syntax can cut in half the lines of code that are normally written with other frameworks, which aligns perfectly with Ruby's vision of keeping code simple and intuitive.
Svelte's popularity is increasing day by day, as developers' satisfaction rate is exceeding that of other frameworks such as React.
Moreover, Svelte is easy to implement and integrate with Ruby-on-Rails. We will take a look at how to do it now.
Ruby-on-Rails application from scratch
In other articles we have seen how to create a fresh new Rails application. However, we are going to review the process in order to get a clear idea of how to integrate Svelte into the application.
Remember that you should have an updated version of Rails and Ruby, as well as the npm package. Also, it is important to install/upgrade the yarn package manager by running:
Prerequisites set up
$> ruby -v ruby 3.1.2p20 # Please use Ruby 3! $> rails -v Rails 18.104.22.168 # And Rails 7 to keep things fresh $> bundle -v Bundler version 2.3.14 # Bundler 2.xx $> npm install --global yarn # npm and yarn package managers
Once we have this, we are ready to start our new project.
Create a new app with rails
bin/rails new svelte-app
Go to the new directory to access the application
Open the project in your source-code editor (i.e. Visual Studio)
Add svelte to the Gem File
# Gemfile ADD: gem 'svelte-rails'
Execute the commands below on the console
bundle bin/rails svelte:install
Run the app on localhost
Rendering the Svelte app
Good job! We have created our new Rails app with Svelte. Before rendering the app we need to make one manual adjustment so that our Svelte code is executed in all the views of the application. Open the file
Once this is done, we can start shaping our app by defining its MVC Architecture. Let's create a controller by running:
rails generate controller demo index
And define the routes in the
Rails.application.routes.draw do get 'demo/index' root 'demo#index' end
Run the rails server on localhost and see how magic happens!
You should go to the view file that has been automatically generated (in this case
app/views/demo/index.html.erb), and delete the two lines to clean the view:
# DELETE: <h1>Demo#index</h1> <p>Find me in app/views/demo/index.html.erb</p>
Now we are rendering the Svelte code according to the following files:
app.svelte This file is the Svelte component that contains 3 sections:
- The script
- The style (CSS)
- The Template (HTML output)
If we play a bit with both files, we can easily render this:
Here you can see how we have modified the mentioned files:
After seeing how Svelte works and how to implement it together with Ruby-on-Rails, we can highlight some important takeouts:
- Svelte's Community is growing, and the Documentation and examples that you can already find are of great value.
- Pace of development is fast. Lately, we have seen the releases of SvelteKit (web applications) and Svelte Native (mobile apps), which are the frameworks to make development experience more efficient.
- Big companies are using Svelte already (i.e. Philips and Rakuten)
- When talking about frameworks, early adoption can be a risk but also a huge win!
When choosing frameworks, it is important to study and assess alternatives (i.e. take a look at this guide about Vue and compare): how does the implementation work? What is more efficient? What pays off in the short/long term?