Skip to main content
thoughtbot thoughtbot
  • We're live Live on Twitch!

    thoughtbot is livestreaming

    Work alongside the thoughtbot team as we collaborate with each other and our clients, live. Ask us anything, we're live right now!

  • Case Studies
  • Blog
  • Let’s Talk
We're live Live on Twitch!

thoughtbot is livestreaming

Work alongside the thoughtbot team as we collaborate with each other and our clients, live. Ask us anything, we're live right now!

Let’s get started!
View all Services
Development
  • Ruby on Rails
  • Hotwire
  • AI and Machine Learning
  • Maintenance
  • Mobile
Design
  • Discovery Sprints
  • UX, UI, and Product Design
  • Design Systems
Product
  • MVP
  • Product Management
  • Accessibility
Team and Processes
  • Team Augmentation
  • Fractional Leadership
View all Services
View all Resources
Development
  • Tech Leadership Resources
  • Open Source
  • Books
  • The Bike Shed Podcast
  • Live Streaming on YouTube
  • Conference Talks
The business of great software
  • Playbook
  • Giant Robots Smashing Into Other Giant Robots Podcast
  • Design Sprint Guide
  • Live Streaming on LinkedIn
View all Resources

Web Articles

Written by thoughtbot, your expert partner for design and development.

    • All Topics
    • Design
    • Development
    • Product
    • More topics
  1. Styling a Middleman Blog with the Bourbon Suite: Revisited

    In 2014 we wrote about how to get up and running with Middleman and Bourbon. This article revisits that technical stack for 2017.

    Cristina Silva
    September 15, 2017
    • Middleman
    • Bourbon
    • Design
    • Web
  2. Lean & Maintainable Reports with Heroku Dataclips

    Write testable reports in SQL that don’t erode over time.

    Oli Peate
    August 21, 2017
    • Data
    • Heroku
    • Rails
    • Web
  3. Nesting grids with Neat 2

    Use Neat 2 to create dyamic nested layouts for your site or app.

    Will H McMahan
    August 8, 2017
    • Neat
    • Bourbon
    • Design
    • Sass
    • Open Source
    • Web
  4. Alternative View Layers for an Elm App

    Get an Elm app to render using your favourite template library.

    Pablo Brasero
    July 10, 2017
    • Elm
    • Glimmer
    • Ember
    • JavaScript
    • Web
  5. Headless Capybara Feature Specs with Chrome

    We’re experimenting with running feature specs using Chrome’s new headless mode. How do we set it up, and how does it compare to Capybara-WebKit?

    Derek Prior
    June 16, 2017
    • Rails
    • Testing
    • Web
  6. Improving the Formkeep and Wistia Experience

    Submitting forms in Wistia is now a smooth and seamless experience.

    Joel Oliveira
    May 26, 2017
    • Formkeep
    • Wistia
    • Web
    • News
  7. Recent FormKeep Improvements

    Formkeep now with dynamic redirects and no longer requiring credit cards up front.

    Joel Oliveira
    May 24, 2017
    • Formkeep
    • Web
    • News
  8. Following the Path

    A journey into requiring files via $PATH and $LOAD_PATH.

    Joël Quenneville
    April 10, 2017
    • Web
    • Ruby
    • Unix
  9. A React Rendering Misconception

    In which we learn how often React renders components.

    Chris Thorn
    April 5, 2017
    • React
    • Performance
    • Web
  10. Decorating ActiveRecord

    Avoid some tricky edge cases when decorating ActiveRecord models.

    Joël Quenneville
    March 31, 2017
    • Web
    • Ruby
    • Rails
  11. Sign up to receive a weekly recap from thoughtbot

    Looking for even more ways to stay connected?
    RSS feed Check out our feeds
« First ‹ Prev … 13 14 15 16 17 18 19 20 21 … Next › Last »

Footer

thoughtbot
  • Services
  • Case Studies
  • Resources
  • Let's Talk
  • Our Company
  • Careers
  • Purpose
  • Blog
  • Events
  • Sponsor
  • Store
  • Mastodon
  • Bluesky
  • GitHub
  • YouTube
  • Twitch
  • Feeds
© 2025 thoughtbot, inc.

The design of a robot and thoughtbot are registered trademarks of thoughtbot, inc.

  • US: +1 (877) 9-ROBOTS
  • UK: +44 (0)20 3807 0560
  • Code of Conduct
  • Accessibility Statement
  • Privacy Policy