sprockets VS importmap-rails

Compare sprockets vs importmap-rails and see what are their differences.

sprockets

Rack-based asset packaging system (by rails)

importmap-rails

Use ESM with importmap to manage modern JavaScript in Rails without transpiling or bundling. (by rails)
InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
sprockets importmap-rails
4 26
923 1,013
0.1% 1.7%
3.3 8.0
about 1 month ago about 1 month ago
Ruby Ruby
MIT License MIT License
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

sprockets

Posts with mentions or reviews of sprockets. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-05-01.
  • Ruby on Rails with React on Typescript using importmaps
    3 projects | dev.to | 1 May 2023
    Have you noticed that we used JSX syntax? It is not what the browser understands by default. In Rails, the Sprockets gem is responsible for translating from the languages that developers like to write to the languages that the browser can run. However, it doesn't compile JSX by default. You can learn from the Sprockets fascinating readme on how to befriend it with new file types, but for JSX it is already done by the creator of the jass-react-jsx gem. Therefore, there is no reason to write the code again that is already written and working. It uses Babel, a JavaScript library that converts one JavaScript to another. It requires Node.js to run. I can't imagine a case where you have a Rails app installed but Node.js isn't, but the fact that I can't imagine it doesn't mean that it's impossible. So lets add babel to our app: Console
  • A Quick and Easy Guide to the Asset Pipeline in Rails 7
    2 projects | /r/ruby | 14 Sep 2022
    Sprockets actually does define those tasks: https://github.com/rails/sprockets/blob/main/lib/rake/sprocketstask.rb
  • February Gnarly Learnings #1: An Introduction to Propshaft
    2 projects | dev.to | 25 Feb 2022
    What an exciting couple of months it has been for the Rails community! Rails 7 was released in December of 2021 and this month we are welcoming Propshaft. David Heinemeier Hansson (DHH), the creator of Rails, released a post on Feb. 11 introducing the community to the new and improved asset pipeline for Rails. While Propshaft likely won't be the default until at least Rails 8, it promises a simpler solution to asset management over its predecessor, Sprockets. Sprockets, the current default asset pipeline library, has grown increasingly heavy over the years as it has attempted to shoulder all things related to bundling, minifying, transpiling, and compressing. Enabled by the new era of tech that makes Rails 7 possible, Propshaft is touted as being "absolutely tiny" in comparison and aims to provide the following: a configurable load path for your assets, digest stamping for long-expiry cache and better performance, a development server that removes the need to pre-compile assets, and basic compilers instead of full transpilers. Sprockets will require relatively long-term support and will remain the default for now but fret not! You can create a Rails 7+ app using Propshaft, or upgrade an existing app and start using it now.
  • Using Hotwire Turbo in Rails with legacy JavaScript
    16 projects | dev.to | 23 Apr 2021
    after being in beta for 3 years, Sprockets 4 was released, with support for ES6 and source maps in the asset pipeline (2019), to serve people still hesitant with webpack,

importmap-rails

Posts with mentions or reviews of importmap-rails. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-04-28.
  • The Rails asset pipeline, old and new
    2 projects | dev.to | 28 Apr 2024
    It is implemented as a thor task in lib/importmap/cmmands.rb
  • RubyJS-Vite
    11 projects | news.ycombinator.com | 15 Apr 2024
    With importmaps (https://github.com/rails/importmap-rails) and Hotwire (https://hotwired.dev/), you write plain js and serve it.

    Also packages are served via CDN. There is no tree shaking. Rails got rid of the whole bundling step.

  • First commits in a Ruby on Rails app
    6 projects | dev.to | 17 Jan 2024
    Importmap audit - “checks the NPM registry for known security issues”
  • Asset compilation taking ~ 12 mins
    2 projects | /r/rails | 6 Jul 2023
    It worked, but JS changes were not coming through. Digging into the Importmap docs (see 'sweeping the cache', it monitors changes according to the setting config.importmap.cache_sweepers. So, by adding the locations where I have my JS files, I also got JS changes passed through.
  • Is the default importmap method unrealistic in the most popular real world use cases?
    5 projects | /r/rails | 9 May 2023
    You can't use TypeScript, or anything that requires pre-compile, with importmap. answered issue
  • Ruby on Rails with React on Typescript using importmaps
    3 projects | dev.to | 1 May 2023
    Let's begin by installing the necessary dependencies. The first gem generates the importmap object, manages caching, and helps with library installations, among other things. I recommend reading the entire readme to become familiar with its capabilities. The second gem will be discussed later, it is used to compile JSX files. Gemfile
  • Pirep.io collects the unpublished, local knowledge on public, private, and unmapped airport that anyone can contribute to
    4 projects | /r/flying | 13 Apr 2023
    Yeah, those were brand new right around the time I started this project a few years ago with Rails 7 (or was it 6.1?). I actually ended up removing them in favor of importmap-rails since I wanted as simple of a frontend as possible and I wasn't sure of relying on what was, at the time, a brand new way of doing frontend work. Things change so quickly in JS-land that I'm always hesitant to make something a dependency unless it has a strong track record of being continuously maintained.
  • Dusting off my rails knowledge, need some tips / guidance on rails 7 and production
    10 projects | /r/rails | 7 Apr 2023
    source "https://rubygems.org" git_source(:github) { |repo| "https://github.com/#{repo}.git" } ruby "3.1.0" # Bundle edge Rails instead: gem "rails", github: "rails/rails", branch: "main" gem "rails", "~> 7.0.4", ">= 7.0.4.2" # The original asset pipeline for Rails [https://github.com/rails/sprockets-rails] gem "sprockets-rails" # Use sqlite3 as the database for Active Record gem "sqlite3", "~> 1.4" # Use the Puma web server [https://github.com/puma/puma] gem "puma", "~> 5.0" # Use JavaScript with ESM import maps [https://github.com/rails/importmap-rails] gem "importmap-rails" # Hotwire's SPA-like page accelerator [https://turbo.hotwired.dev] gem "turbo-rails" # Hotwire's modest JavaScript framework [https://stimulus.hotwired.dev] gem "stimulus-rails" # Build JSON APIs with ease [https://github.com/rails/jbuilder] gem "jbuilder" gem "mongoid" gem "mongoid-grid_fs" gem 'bootstrap', '~> 5.2.2' #sourced from https://github.com/twbs/bootstrap-rubygem gem 'rack-cors' # Windows does not include zoneinfo files, so bundle the tzinfo-data gem gem "tzinfo-data", platforms: %i[ mingw mswin x64_mingw jruby ] # Reduces boot times through caching; required in config/boot.rb gem "bootsnap", require: false
  • Simple Modern JavaScript Using JavaScript Modules and Import Maps
    9 projects | news.ycombinator.com | 16 Feb 2023
  • A powerful search feature with what Rails provides out of the box
    6 projects | dev.to | 19 Jan 2023
    Also, installing StimulusReflex seems quite not easy for the moment: It seems there are some quirks along the way if you're using import-maps for managing javascript dependencies as I do. Embracing the Rails way at least prevents you from this sort of issue.

What are some alternatives?

When comparing sprockets and importmap-rails you can also consider the following projects:

turbo-rails - Use Turbo in your Ruby on Rails app

jsbundling-rails - Bundle and transpile JavaScript in Rails with esbuild, rollup.js, or Webpack.

Turbolinks - Turbolinks makes navigating your web application faster

esbuild-rails - Esbuild Rails plugin

propshaft - Deliver assets for Rails

esbuilder - Integrate esbuild into Rails

Stimulus - A modest JavaScript framework for the HTML you already have

vite_ruby - ⚡️ Vite.js in Ruby, bringing joy to your JavaScript experience

Webpacker - Use Webpack to manage app-like JavaScript modules in Rails

esbuild-live-reload

ruby-coffee-script - Ruby CoffeeScript Compiler

webpack - A bundler for javascript and friends. Packs many modules into a few bundled assets. Code Splitting allows for loading parts of the application on demand. Through "loaders", modules can be CommonJs, AMD, ES6 modules, CSS, Images, JSON, Coffeescript, LESS, ... and your custom stuff.