Skip to main content

Safari 15’s Tab Groups

Posted in Apple

The road to Safari 15 was a bumpy old ride. Some things were announced at WWDC and then sort of undone, like using rounded rectangles for tabs on macOS and extending the website’s background colour into the browser chrome. Other things turned out great, like moving the address bar to the bottom of the screen on iOS, and Tab Groups.

Grouping tabs has been around for a while; Google Chrome launched it for their desktop browsers in 2020, and while their solution makes managing those squillions of tabs a bit more sensible, it doesn’t get to the root of the problem. Yes, you can collapse your groups to reduce the number of tabs on display, but Chrome’s tab groups add even more noise up there in the tab bar:

  • The tab group label (which is also a show/hide button)
  • A continuous line for each ‘open’ group to mark its tabs
  • Colour to provide extra differentiation between groups

With its settings/preferences in a tab rather than a floating ‘pane’, rounded tab shape, and weird ‘kebab’ menu, Google Chrome already feels less like a native Mac app that it should; their tab groups really don’t help.

Safari’s Tab Groups, on the other hand, deal with the same problem nicely by moving the groups to the side bar. This feels in keeping with macOS in general:

  • Tabs look and function like tabs everywhere on macOS
  • Side bars are the de-facto design language for anything where lists of things are central (Mail, Notes, Messages, Photos, Maps, and so on)

It’s an elegant solution and it tidies things up beautifully. No show/hide actions you might not expect, no unusual lines across the the bottom of tabs, no funky colours.

How Safari’s Tab Groups work

The Tab Group label in the sidebar controls the panel to the right, which might be one tab, or a hundred. I tend to keep the sidebar open but if I need more screen space, a quick + + l toggles it hidden.

You might think this would make knowing which group you’re in and navigating between them more difficult but instead of the side bar with the current Tab Group highlighted in the list of groups, you get:

  • A button in the browser chrome with a downward-pointing disclosure chevron, labelled with the current Tab Group’s name
  • A dropdown list of all Tab Groups when the button is pressed, with the current group marked with a tick

Syncing

Abstracting the groups to a sidebar or dropdown menu adds a little to the initial learning curve compared to Google Chrome’s implementation but one huge advantage is that it translates perfectly to mobile.

This means all Tab Groups and their tabs can synchronise seamlessly between all your devices via iCloud. And as you navigate around in each tab, the page is synced automatically across all of your devices, meaning you can pick up on your iPhone where you left off on your Mac.

Enhancement

As all relatively complex design should be, Tab Groups are an enhancement to the way we use tabs, not a replacement. If you didn’t know about them, you would continue to use Safari as you always had; when you start using Tab Groups, you’ll still have a generic, non-grouped tab area for non-grouped tabs.

Managing Tab Groups

Opening a new Tab Group is easy, whether on Mac or a mobile device; you can create an empty group or populate a new one with all the tabs currently in the generic tab area.

Moving tabs from the generic tab area to a group is straightforward, as is moving a tab from one group to another. Either using a right-click/long-press menu or dragging and dropping. Renaming, reordering, and removing Tab Groups is also extremely simple.

Not bookmarks

Tab Groups differ from Bookmarks in that they represent working documents: new tabs can be opened, tabs can be closed, a web page in a tab can be navigated around, and it’s all remembered and synced. Bookmarks are a more permanent place for reference or quick linking. I have GitHub bookmarked, but I also have GitHub open at certain repositories within several Tab Groups.

Organisation

The primary selling point of Tab Groups is that they keep things tidy. Here are some examples of how I use Tab Groups:

  • When I’m doing some research, say for a blog article, or something I’m looking to buy, I’ll open a Tab Group to keep things nicely compartmentalised
  • I have a Tab Group for publishing, with tabs open on my website’s GitHub repository’s Pull Requests page, Netlify’s Deploys page, and so on
  • I’m teaching myself to play the bass guitar, so I have a Tab Group with tablature and YouTube videos for songs I fancy learning

Focus

Aside from organisation, an unexpected benefit of Tab Groups is that they help with focus. I can’t tell you how many times over the years I’ve been searching for a particular website in that mess of tabs, only to be distracted by another tab I’d forgotten about as I cycle through. Because Tab Groups keep things segmented, I don’t have that problem anymore!

Suffice to say, I’m a big fan of Tab Groups, and they’ve become an integral part of how I browse the web. I’m a big fan of Safari in general: it’s fast, easy on my battery and CPU, the most Mac-assed Mac app of all the web browsers; and now it has a great way to keep on top of my tabs!

Accessibility in your inbox

I send an accessibility-centric newsletter on the last day of every month, containing:

  • A roundup of the articles I’ve posted
  • A hot pick from my archives
  • Some interesting posts from around the web

I don’t collect any data on when, where or if people open the emails I send them. Your email will only be used to send you newsletters and will never be passed on. You can unsubscribe at any time.

More posts

Here are a couple more posts for you to enjoy. If that’s not enough, have a look at the full list.

  1. Images as the first thing in a button or link

    If the text of an interactive element like a button or link is preceded with an accessible image, we’ve probably got an accessibility problem.

  2. Alt text for CSS generated content

    There’s an interesting feature in Safari 17.4 that allows content added with CSS to have ‘alt’ text. I’m not sure how I feel about this.