aboutsummaryrefslogtreecommitdiff
path: root/build/sticky-elements/index.html
diff options
context:
space:
mode:
Diffstat (limited to 'build/sticky-elements/index.html')
-rw-r--r--build/sticky-elements/index.html83
1 files changed, 83 insertions, 0 deletions
diff --git a/build/sticky-elements/index.html b/build/sticky-elements/index.html
new file mode 100644
index 0000000..ffd9408
--- /dev/null
+++ b/build/sticky-elements/index.html
@@ -0,0 +1,83 @@
+<!doctype html>
+<html lang="en" id="top">
+<head>
+ <meta charset="utf-8">
+ <meta name="viewport" content="width=device-width, initial-scale=1">
+ <link rel="icon" href="data:,">
+ <title>Stop Using Sticky Navigation on Mobile</title>
+ <link href="https://bt.ht/atom.xml" type="application/atom+xml" rel="alternate" title="Atom feed for blog posts" />
+ <style>*{box-sizing:border-box;}body{font-family:sans-serif;margin:0 auto;max-width:650px;padding:1rem;}img{max-width:100%;}pre{overflow:auto;}table{text-align:left;width:100%;}</style>
+</head>
+
+<nav>
+ <a href="#menu">Menu &darr;</a>
+</nav>
+
+<main>
+<h1>Stop Using Sticky Navigation on Mobile</h1>
+<p>2019-10-06</p>
+<p>Stop styling your web elements to be "sticky" on mobile. This creates a horrible experience for your users and also looks like trash from a UI perspective. Don't style your navigation (or any components for that matter) to be "sticky" on mobile. They create poor experiences for your users and take away valuable screen space.</p>
+<h2>What do you mean by "sticky"?</h2>
+<p>The concept of <em>sticky</em> elements include but are not exclusive to:</p>
+<ul>
+<li>Navigations that follow users as they scroll</li>
+<li>Chatbot prompt bubbles eating up half the bottom of the screen</li>
+<li>Banners or modal prompts that pester the user to "sign up, accept cookies" etc.</li>
+</ul>
+<p><strong>These are bad and you should feel bad for implementing them.</strong> Spacing and layout is a critical part of a product’s design and greatly impacts the experience of its users. Stop screwing it up with ugly sticky elements.</p>
+<p>First, let's breakdown "sticky" navigations and why they're terrible. We'll also go over some easy solutions to avoid making these bad design decisions in the first place.</p>
+<h2>The stalking navigation</h2>
+<p>When you make a decision to eat away <code>&gt;50px</code> of space at the top of the page for your site's navigation - you're hurting your users. You're also making their time interacting with your website more painful.</p>
+<p>"Wait!" I hear sticky-nav defenders exclaim, "this navigation bar makes it so the user can <em>easily</em> interact with the site's pages!"</p>
+<p><strong>What absolute rubbish.</strong> A user should only see a website's navigation when they <em>need to use it</em>. This isn't rocket science.</p>
+<p>Let's a take a look at the problem:</p>
+<p><figure>
+ <img src="/public/images/sticky-bad-navigation.webp" alt="Bad navigation" />
+ <figcaption>Fixed navigation: you lose valuable space for an element that might only be used once per visit (<a href="/public/images/sticky-bad-navigation.webp">direct link to image</a>)</figcaption>
+</figure></p>
+<p>Knowing when to show navigation can be easily solved where the user isn't bogged down with a chunk of their screen permanently taken away, all the while still having access to the navigation. This can be fixed by simply understanding the user context at a given time. See below:</p>
+<p><figure>
+ <img src="/public/images/sticky-good-navigation.webp" alt="Good navigation" />
+ <figcaption>Static navigation: users can focus on what is important - <strong>the content</strong> (<a href="/public/images/sticky-good-navigation.webp">direct link to image</a>)</figcaption>
+</figure></p>
+<p>Here the navigation flows up with the rest of the page as the user scrolls the main content into view. Don't worry about creating confusion - the user knows the navigation is still at the top of the page because they <em>watched it scroll out of view</em>. This is best paired by having a matching navigation in the footer of the page as well. That way, when the user makes it to the end of a specific view they can change pages right in the "footer". No need to scroll back to the top.</p>
+<h2>The best of both worlds?</h2>
+<p>Maybe you want to hide the navigation without losing the flexibility of it always being accessible at the top of the page? This is possible, although I find it still <em>somewhat</em> intrusive on the user. An easy way achieve this is by displaying the navigation when users perform a specific action, such as:</p>
+<ul>
+<li>Long or multiple upward swipes on the page</li>
+<li>Pull down menu from top of current view (easily shown to user)</li>
+</ul>
+<p><figure>
+ <img src="/public/images/sticky-good-navigation-2.webp" alt="Good navigation displaying top navigation" />
+ <figcaption>Dynamic navigation: show the user the top navigation when a certain action is performed (<a href="/public/images/sticky-good-navigation-2.webp">direct link to image</a>)</figcaption>
+</figure></p>
+<h2>Navigations aren't the only culprits</h2>
+<p>I wish that navigation items were the only sinners of the "sticky" position on mobile - but they are not alone. A few other problematic components include:</p>
+<ul>
+<li>Chatbot or support "bubbles"</li>
+<li>"Agree to our cookies" prompts</li>
+<li>Time-based pop-up modals</li>
+</ul>
+<p>Every time you implement one of these components, somewhere in the world a puppy dies. Seriously - don't be part of the problem and build these things. Push back on "marketing research" or team leads who tell you that this crap works. You're making the mobile web worse for everyone and setting a terrible precedent for future developers.</p>
+<p>Stay <em>static</em>, my friends!</p>
+<footer role="contentinfo">
+ <h2>Menu Navigation</h2>
+ <ul id="menu">
+ <li><a href="/">Home</a></li>
+ <li><a href="/projects">Projects</a></li>
+ <li><a href="/uses">Uses</a></li>
+ <li><a href="/wiki">Wiki</a></li>
+ <li><a href="/resume">Resume</a></li>
+ <li><a href="/colophon">Colophon</a></li>
+ <li><a href="/now">Now</a></li>
+ <li><a href="/donate">Donate</a></li>
+ <li><a href="/atom.xml">RSS</a></li>
+ <li><a href="#top">&uarr; Top of the page</a></li>
+ </ul>
+ <small>
+ Built with <a href="https://git.sr.ht/~bt/barf">barf</a>. <br>
+ Maintained with ♥ for the web. <br>
+ Proud supporter of <a href="https://usefathom.com/ref/DKHJVX">Fathom</a> &amp; <a href="https://nextdns.io/?from=74d3p3h8">NextDNS</a>. <br>
+ The content for this site is <a href="https://creativecommons.org/licenses/by-sa/2.0/">CC-BY-SA</a>.<br> The <a href="https://git.sr.ht/~bt/bt.ht">code for this site</a> is <a href="https://git.sr.ht/~bt/bt.ht/tree/master/item/LICENSE">MIT</a>.
+ </small>
+</footer> \ No newline at end of file