Creating a strong performance culture means creating a feedback loop in your company or team that looks like this:
In other words: Get people to care, show them what they can do to help, and then give them positive reinforcement when you get results. It's basic human psychology, and it might seem obvious when you see it in a super-simple graphic. But it's surprisingly easy to miss these steps, skip ahead to the part where you invest in awesome performance tools, and then wonder why all your performance efforts feel like such a painful uphill slog.
Here are some proven tips and best practices to help you create a healthy, happy, celebratory performance culture.
1. Identify what people care about
If you ask different people in your organization how much they care about performance today, you might just get a bunch of blank stares. But if you gave them a checklist and asked them to tick off any of the following boxes of things they care about, you'd probably get a more enthusiastic response:
- bounce rate
- cart size
- time on site
- page views
- search traffic
- user satisfaction
- user retention
Over the years, I've learned that performance can be mapped to all of these metrics – and almost any other business metric you can think of. To hook different people on performance, you need to understand which metric motivates them.
For example, an executive might want to know the impact of performance improvements and slowdowns on conversions and overall revenue, while folks in your marketing team might focus on the impact of performance on everything from SEO to user engagement.
Once you know what people care about, connect the dots for them. Case studies are an awesome way to do this, which is why I've been helping curate WPOstats, a vendor-neutral directory of performance case studies. For example, if someone on your executive team cares about conversions and revenue, you can direct them to a set of studies that focus on the impact of performance on revenue and conversion rate. People on your marketing team probably care about traffic and engagement. And so on.
Case studies are a great way to convert performance skeptics. They're also a great way to get people fired up about making your site faster. When you learn, say, that Staples reduced its median load time by 1 second and saw a 10% increase in conversion rate, that's pretty compelling.
How SpeedCurve can help: Case studies from other companies are compelling, but using your own data is even more compelling. If you're a SpeedCurve LUX user, the user engagement charts that are the top of your Performance dashboard are an easy way to illustrate the correlation between performance and bounce rate using your own data. (One thing we've found is that almost everyone can relate to bounce rate as a meaningful metric.)
2. Fire up people's competitive spirit
One of the fastest routes to getting people to care about performance is to show them how slow their site is compared to their competitors. One of the great things about synthetic monitoring is that you can test any page on the web, not just your own. This lets you do great things like generate side-by-side filmstrips – and even better: videos – of your site alongside your competitors' sites (or any other aspirational sites).
3. Make things visible (but not overwhelming)
If you want to see non-technical stakeholders' eyes glaze over, show them an endless series of dashboards and charts. Less is more is your mantra. In the same way that you need to understand what motivates different people in your organization, you also need to tailor your reporting. For some people, your performance report might be just a single graph or a very simple dashboard that shows them the data points they care about. (It stands to reason that you should always be ready to go deeper upon request.)
One excellent practice that's used effectively by companies like Lonely Planet and Ticketmaster is to have monitors mounted in open areas of their offices, displaying key performance stats and comparison videos. Lara Hogan (previously director of engineering at Etsy) wrote a great blog post demonstrating how Etsy took advantage of the power of showing versus telling.
How SpeedCurve can help: You can start by creating separate dashboards for different stakeholders. Each dashboard contains only the graphs that are relevant to that stakeholder group. (We've also made it easy to share your dashboards and comparison videos, with "share" icons that give you URLs you can email or use on your wall monitor.)
4. Collaborate on performance budgets
Performance budgets are an important tool for ensuring your site is delivering a great user experience. The practice of using budgets to track performance took off with this post by Tim Kadlec. The idea is to identify your performance goals, then track the metrics that help you achieve your goals. Setting performance budgets lets you focus on the metrics you care about most, create goals, set budgets based on those goals, and get alerts when those budget thresholds are crossed.
As mentioned near the top of this post, there's no one-size-fits-all unicorn metric that will get everyone in your company excited about performance. This means there's no one-size-fits-all metric you should focus on for your performance budgets. Instead, your performance budgets can run a gamut that includes:
- Someone in ops needs to know Time to First Byte so that they can investigate back-end issues.
- One of your developers might care about start render or Speed Index, because they want to get a sense of how well the page is built – for instance, are there any blocking scripts or stylesheets.
- Someone in your marketing team wants to know how quickly the page delivers the most important content from a user's perspective, so they might want to track the rendering of hero images.
To make people accountable, give them ownership over their performance budgets and make sure they receive alerts when their budgets are exceeded.
Super important: No sandbagging allowed. You wouldn't say you're going on a diet, then give yourself a limit of 3000 calories a day. In the same way, you want to keep your budgets realistic without making them overly forgiving. The point of a performance budget is to blend the aspirational with the achievable.
How SpeedCurve can help:
- Create performance budgets around specific metrics (e.g. page size, start render, custom metrics, etc.) for your pages, and send alerts – via email, Slack, and HipChat – when your numbers go out of bounds. Here's how Zillow uses SpeedCurve to create and enforce performance budgets.
- Your Status dashboard lets you monitor and manage all your Synthetic and LUX performance budgets – and see budget violations – in one place.
- Generate weekly email reports. Turn any Favorites dashboard into an email report that contains a week-over-week comparison of your data.
5. Score some easy wins
If you're new to performance – or if you're tackling a site that's new to you – there's a good chance there's some low-hanging fruit you can optimize. The first places to look are images and blocking stylesheets and scripts (especially third parties).
For example, the team at Fanatics.com did a one-month performance sprint where the most impactful changes they made were simple image optimizations: they improved image quality and compression, and they fixed an image sprite that was blocking pages from rendering. As a result, they saw a 2-second improvement in median load times and almost doubled their mobile conversions – a really big deal, since more than half their revenue comes from mobile. This relatively easy win was a fantastic way to get performance buy-in throughout their company.
How SpeedCurve can help: With synthetic monitoring, you can drill down to find the most critical defects that are hurting specific pages. Pair that with real user monitoring, which lets you map performance to biz metrics like conversions.
We live in a culture that doesn't celebrate success as much as it should. (Disclosure: I'm totally guilty of this.) So consider this a reminder: Every time you move the needle on performance – and that moves the needle on user engagement or revenue or whatever your company cares about – shout it from the rooftop. Or if that's not allowed at your office, email is fine, too.
Here at SpeedCurve, we have a #ring_the_bell Slack channel where we share wins and milestones, both big and small. And in the spirit of Lara Hogan's donut manifesto, we send each other fun gift baskets to celebrate victories.
7. Share what you've learned
Shouting from the rooftops (or sending celebratory emails) is a great start. Next, share what you did and what you learned. This can be in the form of company- or department-wide emails, posts on your in-house dev blog, and internal meetups. I know of some performance teams that do regular monthly technical meetups, and once or twice a year do a company-wide event where they share all their greatest web perf stats and victories.
Membership in a healthy performance culture also means embracing the fact that you're part of a culture that's much bigger than your company. There are so many ways to get involved and to learn from other webperf enthusiasts:
- Share your case studies and successes (if your company allows it) on a public-facing tech blog like Etsy's Code as Craft, Cars.com's Tech Blog, and the Financial Times' Engine Room.
- Submit your success story to WPOstats.com – a repository of performance case studies. (Disclosure: I'm one of the curators.)
- Follow the #webperf hashtag on Twitter.
- Participate in one of the many Web Performance Meetups around the world.
- Attend performance-oriented conferences like #PerfMatters, DeltaV, SmashingConf, and performance.now().
- Cars.com explains how they use SpeedCurve to create a performance culture.
- This RWD podcast episode is with a couple of members of Vox Media's performance team. Among other things, they do a great job of talking about perf culture.
- Lara Hogan has written an excellent book called Designing for Performance, and she's kindly made the text available online. The entire book is great, and chapter 8 is dedicated to performance culture.