Back

Overengineered Anchor Links

241 points10 hoursthirty-five.com
LinuxAmbulance9 hours ago

As a backend person, sometimes I look at what's being done for front end stuff and pull back in ever so slight horror.

It's an excellent article, and the work within is very well done, but there's a part of me that screams "Why would you introduce this much complexity for what should be a simple scroll?" (overcoming technical hurdles to produce the desired end result aside).

madeofpalk5 hours ago

I think the article does a pretty good job of explaining the gap between what can happen easily, and what a 110% over engineered "perfect" solution is to a UX problem.

Building excellent user interfaces is hard, regardless of the technical stack. You have to sweat a lot of the finer details, break out of any platform default behaviour where appropriate, and over engineer something in service of building a 'delightful' user experience.

Or, you can do as most do, and just not do this. #anchor-links with `scroll-behavior: smooth;` CSS will get you the basic smooth scrolling.

maccard2 hours ago

The really hard part of that is that if you can’t build an excellent interface, you will build a worse one than if you used the native interface. So you either need to be prepared to sweat every last detail forever.

philsnow7 hours ago

Frontend is completely inaccessible to me.

From time to time I dip my toe in and try new things, but as productive as I can get with Astro, the illusion vanishes as soon as I have to understand any of the plumbing.

Fortunately, I can still party like it’s 1999 just fine: just yesterday, I worked on a janky brutalist web app (the same way I did back in 2002, cribbing from the O’Reilly “Dynamic HTML: the Definite Reference”) and “deployed” it with rsync to pico.sh. It’s practically unstyled and I didn’t even use jquery, but it works.

moron4hire7 hours ago

The thing is, backend stuff is largely solved. You need to store data? Here you go, here's a database. You need to process a bunch of strings for similarity? We got an algorithm for that.

But frontend stuff is messy. How do you tell a person what they're trying to do is wrong and they need to change their inputs? Oh, maybe we can highlight the input or we can pop a modal message. Haha, psyche! Users ignore that shit! Now what you gonna do, buddy?

Frontend is a mess because all you people are a mess.

lenkite1 hour ago

Well if it continues to be a mess, something like WASM-based flutter-web might just eat the frontend

myth20182 hours ago

I think the biggest problem is that HTML and even HTTP weren't developed with those use cases in mind.

Before WWW was a thing we already had user interfaces and the fact that current users frequently prefer those ancient, text user interfaces over modern ones tells a real LOT.

bathtub3657 hours ago

Contempt for your users inevitably leads to bad products so it’s no wonder things are bad if this is the prevalent attitude among front end web developers.

+1
singingboyo7 hours ago
xmprt4 hours ago

I don't read it as contempt but rather the equivalent of a backend engineer saying that you can't trust user inputs and need to validate, authenticate, and authorize every request.

+1
throwaway9w47 hours ago
rfgmendoza5 hours ago

contempt for users is the unavoidable consequence of having users.

+1
evilduck5 hours ago
moron4hire7 hours ago

I don't have contempt for users. I have contempt for single-issue developers who have never stepped out of their little corner of software who act like front end should be easy because it's "just" some scripting.

pedroma3 hours ago

I'd imagine consumer hardware is the same.

For example, every Thunderbolt dock's internals are basically the same, while the outer shell tries to be as different as possible.

mattpallissard7 hours ago

> Frontend is a mess because all you people are a mess.

As a backend guy who considers himself extremely fortunate that nearly all of his users/customers are technical, this got an audible chuckle out of me.

busymom06 hours ago

I believe it's because on the frontend, everyone wants to look different and have a unique identity. Whereas on the backend, everyone needs to be the same to follow standard best practices.

anon70002 hours ago

Well, part of that is a business need (your app/website/whatever is an extension of your brand, which is a very important part of making money). The other part is there are actually many valid ways to style a button, or have some kind of hover animation, or some kind of navigation bar.

Sure, there are some guidelines and best practices, but there are just infinite ways to display information to people. You can't just look at a technical specification for how well X/Y/Z performs because design is subjective and humans are all different. Whereas none of your users will complain if you use Redis (or similar) for caching something on the backend.

moritzwarhier3 hours ago

It's interesting that you used "wants" in the first sentence and "needs" in the second.

Not saying that you're totally wrong, but I think this difference is not necessarily a deliberate decision by individual engineers, or caused by personality or skill level.

The employee market demographics surely play a role, but this is about concretions, not generalizations.

There is no lack of (often poor) generalizations when it comes to the skills and requirements demanded by BE and FE roles, respectively.

Not wanting to dismiss your idea / the grain of truth. But IMO you are falsely generalizing.

Also, there are not only FE devs claiming to be "full stack" when they don't know HTTP basics.

There are also BE developers with similarly daunting knowledge gaps.

Or in other words, in both worlds there are juniors masquerading as seniors and the other way around, depending on the organization.

nkrisc7 hours ago

Because the default behavior, the problem they describe in the introduction, is bad. It confuses many people, I’ve seen it firsthand many times as an observer in usability testing.

erikpukinskis6 hours ago

Is it really necessary to highlight the heading at all?

I’m a passionate frontend engineer, but I do think we are often busy “asking if we could”, and ignore “if we should”.

Worth noticing, on mobile you can’t even read the conclusion in the “it’s beautiful” demo, because the navigation covers it.

I understand that it is just a demo, and that issue could be solved independently…

But I think it also points at the observation that when you try to do these kinds of unusual things, you open yourself to unintended consequences.

And while you can mitigate those consequences one by one, my experience is that you generally won’t have a chance nailing them all, unless you are also minimizing their number… by not getting too fancy.

nkrisc2 hours ago

All I know is the default browser behavior for anchor links within a page has real usability issues when you have anchored headings at the bottom of the page.

You are correct though that there are many cures worse than the disease, but it is a real "disease", so to speak.

matser9 hours ago

Because I thought it would be fun :)

steve_adams_868 hours ago

It is fun! The person you're responding to isn't wrong; front end is a little horrifying. But it's kind of like a jungle in that the scary beasts, swamps, poisonous plants, and the harsh elements are accompanied by incredible opportunities to experiment, explore, discover, and appreciate beauty.

Backend presents some awesome opportunities too, but I absolutely love weird problems like the one you're solving here. It's in the realm of simultaneously necessary and totally unnecessary. This is where interesting stuff happens!

tshaddox5 hours ago

You say "backend" but I'm guessing you're not talking about modern cloud infrastructure work, the complexity at which I (as a frontend person) scream in similar abject horror.

paulddraper3 hours ago

> Why would you introduce this much complexity for what should be a simple scroll?

The article explains the "why."

> overcoming technical hurdles to produce the desired end result

Yes.

mardifoufs7 hours ago

That's only because you are used to the over complexity of backend work. As someone who is pretty far removed from both front and backend work (or web work in general), both seem pretty complex. Frontend at least has the excuse of being at the interface between humans and computers, which is inherently much harder

svachalek8 hours ago

I remember the days when every new project started with "now let's write our own String class". As someone who works on both, it seems server and native software left this era in the distant past, but we're still there in web development.

type_enthusiast9 hours ago

One could ask: what's the UX purpose of the "active anchor" indicator on the side navigation?

One answer I can think of: if a reader is in the middle of a long section, and the heading is off the screen, it can remind them which section they're in relative to the others.

This indicates (to me, anyway) that it's not a function of which heading you've scrolled to; it's a function of which section is on screen. If you use section-screen-area or something similar to highlight the active section, fiddling with the heading positions becomes unnecessary.

If you have a tiny section at the end that can never take up the majority of the screen, then when the user is reading it, the active indicator won't really be useful anyway.

layer88 hours ago

I find such active anchors incredibly distracting. It’s like something blinking at the side (or top) just because you’ve scrolled a bit.

Regarding the purported problem they solve, maybe browsers should have an option to show current-heading information, similar to how IDEs show in which function or the like you’re in within the current source file.

hinkley8 hours ago

The blur he put on the floating UI elements was also distracting af.

I would spend political capital not to hire this person.

swyx9 hours ago

or if you sticky the current header, thats 1 line of CSS

dahauns5 hours ago

Please...don't. Vertical space is chronically in short supply.

Y-bar10 hours ago

I clicked, thinking that it was perhaps someone who like me was annoyed by Jira's anchors/permalinks which is a <span> with a <button> with a JS event listener on click to load what would normally be an <a href> into the DOM.

But this, this is similar, but different. I can't navigate to anchors with for example the keyboard.

Question for the author: Why not use the HTML <a> element rather than a JS event listener on a non-interactive element?

superkuh10 hours ago

I thought the same. And on this site I cannot even see the proposed anchor link because it's a badly implemented web component custom-element that is all JS defined instead of wrapping actual HTML elements/text. It's such an overengineered anchor link that unless you succssfully execute all the javascript it doesn't appear at all. Very fragile.

> But if you ever had to implement them, you might have encountered the .

Wikipedia is also bad about JS-dependent false anchor links. I can't count the number of times someone "linked" me an "anchor" to an image on a wikipedia article that simply did nothing without javascript. All wikipedia would have to do is put a real html a anchor next to the JS defined one to fix it but despite submitting bugs about this it's never been fixed.

ryandrake9 hours ago

This seems like another case of the web development industry (in general) "fixing" "problems" that aren't really serious problems. I don't know of any user who would be confused by simply being at the bottom of a web page. I didn't look at the code, but my guess is it's a lot of Javascript spending cycles on my machine to solve a non-problem.

I suppose the article author disclosed right away that it's "overegineered" so maybe the post is more of a joke or exercise in absurdity? Nobody would really spend time doing this for a real project, right? RIGHT?

hombre_fatal9 hours ago

Adding padding below the main page content seems ideal since it also fixes the issue where the tail end of the content is stuck at the bottom of the viewport instead of where you'd prefer it.

Maybe a 90vh margin for mobile and 50vh for everything larger.

Hmm, then again you'd still need TFA's solution for the latter case. The margin only solves it on mobile since a 90vh margin on desktop would look ridiculous.

layer88 hours ago

Absolutely this. You can use that space by having a generous footer with all your contact links and such.

hombre_fatal8 hours ago

Yeah, good point. It's kinda common to have a big footer.

Examples: https://getbootstrap.com/, https://discord.com/, https://tailwindcss.com/

That way on desktop you could get away with a 50vh margin under the content and then another 50vh for the footer. That's free overscroll.

jopsen5 hours ago

Yes, the boring solution is often the best.

cmgriffing3 hours ago

I recently discovered the way Tanstack does this. Basically, if the heading of the section is in the viewport, then the list item is highlighted.

So you could have multiple items highlighted, but it still "works" somewhat intuitively for the end user.

The drawback is that it requires JS via intersection observer. But maybe the CSS standards committee could see value in this kind of thing eventually.

whirlwin7 hours ago

In modern browsers, Text fragments let you highlight specific portions of text on a page, be it at the bottom or anywhere. In Chrome, just highlight the text and right click -> Copy link to highlight.

I use it every day instead of anchors to highlight very specific parts of the text, to avoid referring to the whole section with an anchor. Some pages don't even have anchors

Ref: https://developer.mozilla.org/en-US/docs/Web/URI/Reference/F...

mhitza5 hours ago

Interesting that none of those examples work on Brave on mobile. I wonder if those been used covertly for user tracking somehow before.

wrsh079 hours ago

It's hilarious reading the other comments. I'm on mobile but my first thought was how interesting and novel the site design was and how clearly communicated the problem they were trying to solve

Cool post! It's refreshing to read a blog that doesn't ask me to subscribe with popups etc and gets into technical weeds

matser9 hours ago

Thanks! Site is still in stealth alpha and posted an article here in hopes to get -some- feedback. Didn't expect this kind of anger hahah. Very grateful for the positive comments though.

Im on the fence about pre-opening the 'tiles' on mobile. Do you (or anyone else) have any strong opinions on that?

wrsh076 hours ago

I thought everything was pretty easy to use as soon as I realized what clicking a button would do (a little trickiness if you open the tile while the button is nearly off the top of the screen but honestly really great)

Because I don't know what the drop off rate is when someone reads this, take what I say with lots of salt.

Giving one button as a demo and then saying click on button to close (and leaving it implicit that the rest of the buttons need to be opened manually) seems good? Leaving them closed by default worked great for me!

tyzoid8 hours ago

I'm not seeing them show up, with or without JS enabled (firefox on android). I might suggest having some interaction for non-js users though (details element, perhaps?)

noahjk9 hours ago

Once I got over my fear of clicking their links, which I assumed would open a new page (but instead just expanded a pane in-line), I really enjoyed it. I’m very wary of opening new pages. (Also, I first tried to hold-click on the link to open in new tab, but it just behaved like regular text and highlighted, which led to a momentary confusion. I would have preferred a more obvious indication of what would happen when clicking, like a down chevron or something.)

jw_cook1 hour ago

I also assumed those were going to be links, but after a second of confusion I really liked the side pane with animations. It adds a lot to the article and it's more pleasant than the usual alternatives (lightbox on top of the text, or opening a bunch of tabs).

Off the top of my head, I'm not sure how else you'd visually communicate "this bit is interactive on click/hover but isn't a link." Maybe a different text color (without underline), background color, outline (replaced by the colored highlight bar on hover), or a slightly larger and more distinct icon to replace the generic 'image' icon?

creata8 hours ago

Yeah, styling it as a link makes it a bit unclear as to what it's going to do.

matser8 hours ago

Thanks!

creata8 hours ago

Thanks for publishing the article. Idk if my comment sounded too harsh; sorry if it did.

If you're taking more unsolicited nitpicky suggestions, imo the ToC items on the left could use cursor:pointer and a background color change on hover.

carlosdp10 hours ago

The article is a neat read! The design of the blog itself is even more interesting. I don't love the right-aligned way it starts, but I love the inline activations of the left popup! So cool

matser10 hours ago

Thanks! It has some cons, like worse scanability. But I think its really cool that you can have something open next to your paragraph, especially when you need to consult the popup quite often. Like, a table with a bunch of data would also be quite nice with this approach I feel.

If you have any feedback I'd love to hear it!

silveraxe937 hours ago

The way https://gwern.net/ does it is quite good.

The links open in a window, so you can still have centre aligned text with popups.

ramoz9 hours ago

Just flip them.

whiddershins9 hours ago

i've been wanting to implement a design like this for blogs for 5 or 10 years. Great work on the inline detail on mobile. genuinely better than whatever i would have made.

did you consider pushing the word(s) directly following the activation button to below the detail pane, rather than doing it based on line break?

nizarmah10 hours ago

The animations on the left are exactly what my primitive mind needs to understand better and stay engaged while reading an article. I _love_ it.

Etheryte8 hours ago

Another aspect of over engineered anchor links seems to be that at least on Chrome on iOS, back navigation doesn't work properly on this site as a whole.

inetknght9 hours ago

So what's going on for someone who doesn't have javascript enabled? No anchor links are available at all.

j_san4 hours ago

Hey, another overengineer! :D

My solution was to just highlight the last anchor if the user scrolled to the very bottom. Although this might skip the second last heading if its too close to the bottom.

See here: https://sharezone.net/privacy-policy (most visible on desktop, on mobile you have to open the "Inhaltsverzeichnis" at the bottom)

jer0me8 hours ago

Another solution I quite like is highlighting the headings of all the sections that are currently on screen.

codazoda7 hours ago

I agree…

I don’t think this is a real problem that needs solving; or I at least think it’s a problem browser vendors should solve, but lets over engineer it while still trying to keep it simple and usable…

What I might do is something similar to what you’re suggesting. I would have the anchor tag be a regular old anchor tag. Then, I’d highlight the heading (maybe just temporarily) at the same time. I’d use CSS if I could figure that out or JS if I couldn’t. The end result would send the user to the normal place and flash a highlight on the heading for users with JS support.

Keep it simple, but over engineer it to make whoever requested this happy.

Edit: After re-reading your response we probably aren’t talking about the same thing, exactly.

technojamin7 hours ago

This seems like the obvious solution to me. You don't know what the user's eyes are looking at, so making the highlighting a visual representation of what's in the viewport seems preferable than nominating a single section as "current".

In fact the final solution is pretty bad. Sure, it looks nice when I scroll down, but when I use the alternative navigation method of clicking the sidebar items, it just scrolls to unexpected places.

Beautiful article, though.

daef5 hours ago

my first instinct would be to let the triggerline move with the scrollposition, i.e. at scrollTop = 0 the triggerline is at 0vh and at scrollTop=max at 100vh... am i missing something?

riz_4 hours ago

this is the best solution.

sprobertson8 hours ago

FYI on the topic of scroll position, it seems inconsistent between history navigation. For example scroll to the very bottom, click your Internship blog post, and go back - it ends up somewhere towards the end but not quite. (Chrome Mac)

On mobile just clicking the other blog post takes me to the end of that post. (Chrome iOS)

watersb3 hours ago

As of iOS 18.4, macOS 15.4, Details/Summary HTML tags can be styled with CSS.

Which might be an approach for the first few examples.

I am sure there are other cases that would need anchors.

trainspottinfly10 hours ago

Interesting solution. One little tip, I would advise picking a different heading for the section "The final solution". That phrase has a bit of unfortunate historical baggage.

matser10 hours ago

Ouch, thanks for the heads up

fourseventy9 hours ago

[flagged]

johnisgood10 hours ago

I have no idea what "The final solution" refers to in terms of this website that is negative; context matters.

larusso10 hours ago

It refers to the “Endlösung” of the Jew problem in Nazi germany.

numeri9 hours ago

It was the term invented by the architects of the Holocaust, and I disagree that "eh, context matters".

Setting all moral arguments aside, it's important to know that similar phrases can work as dog-whistles to signal belonging to radical groups, and as such can easily give people the wrong impression about you as an author.

If I were to see a blog post titled "Work will set you free"[1] written by a peer, prospective employee/employer, colleague, etc., it would immediately set off alarm bells in my mind – even if the content of the post is a completely innocent discussion of the uplifting benefits of buckling down on one's workload. At best, it implies lack of awareness – at worst, it implies some extremely hateful beliefs and desires.

[1]: Written above the entrance to the Nazi concentration camps as a false promise encouraging prisoners often destined for death to work hard in forced labor.

johnisgood9 hours ago

We ought to change the whole IT terminology then. We keep killing parents and children. Context absolutely matters. Lack of context awareness is a deficit one should work on.

+1
numeri9 hours ago
Jeremy10269 hours ago

It is the culmination of the holocaust.

immibis9 hours ago

The penultimate step. The final step was the Allies stopped the German final solution, and sent them off to colonize Palestine instead (while keeping the gays in the concentration camps because the Allies were homophobic too).

immibis9 hours ago

Baggage which is back in vogue this year.

awayto10 hours ago

I dabbled with this kind of issue in my docs and ended up using JavaScript's Intersection Observer [0]. It's not a perfect solution [1], but I think it worked well enough [2]. It just identifies when the element comes on screen and then marks it as active however you please. I do appreciate the depth the article went into though!

[0] https://developer.mozilla.org/en-US/docs/Web/API/Intersectio... [1] https://github.com/keybittech/awayto-v3/blob/main/landing/la... [2] https://awayto.dev/docs/0.3.0/

ruduhudi9 hours ago

This is by far the best solution. Super simple and covers all those issues.

soneca9 hours ago

Nice read. Although I much prefer the first solution, the hotfix of adding extra padding to the bottom. UX-wise, not just because it is simpler.

On large screens I prefer to not read texts at the bottom (I always scroll things enough so I am looking at them at the middle or top of the screen). Also, the positioning of the heading relatively to the screen is always the same on every scroll.

noahjk9 hours ago

While I usually detest giant footers, this is one use-case they lend benefit to, without causing a large empty space (which some people would then want to fill with an image). I agree from a UX perspective that I prefer when sites act the way I expect them to, and not try to do novel calculations of stuff (minus usability stuff like the ‘dead zone’ dropdown menu polygon calculation). On most pages, I expect a reading section to start when I scroll past a heading, and I prefer anchors to deliver the heading at the top of my viewport.

JackYoustra5 hours ago

Fantastic blog post. I love constrained optimization, it's always pretty to throw a solver at a well-defined problem

sntran7 hours ago

The new CSS Overflow Specification 5 has scroll-marker that can replace anchor link. From my short test in Chrome 135, they seem to scroll to the right place.

Philip-J-Fry9 hours ago

Sounds like a nice solution.

Seems like if you open the "he thinks" image thing at the bottom, and then go back to the "beautiful" result, then it no longer works and the Conclusion heading doesn't get activated. That's how I reproduced it anyway.

asynchronousx8 hours ago

Just came to say the blog site itself is awesome, I’d advocate for opening the diagrams automatically on mobile, they’re amazingly slick.

layer88 hours ago

I missed that there were diagrams because I immediately activated reader mode at the top.

kubb9 hours ago

Cool I like the exercise in futility :)

anon1159 hours ago

can you make them automatically trigger on scroll if you get close to its section?

cynicalsecurity10 hours ago

Why not open a modal dialog instead?

encom4 hours ago

The answer to this question should always be "no". Under all circumstances.

miragecraft4 hours ago

In the final demo, when I click on "Conclusion" in the side nav, it doesn't even bring the content into view.

lugao10 hours ago

[flagged]

matser10 hours ago

It's something new IMO but we are definitely working on improving UX still. Fixing the overscroll issue as we speak. I'm assuming you're using mobile, would you prefer it of the 'tiles' all started in an open state?

It is not an experiment in how bad front end design can be pushed to be... Although that would be a fun blog post

meowface10 hours ago

I think the site looks fine. Just remove whatever is changing the scrolling and adding "smoothness" to it or whatever. Showing stuff as you scroll is cool, but interfering with the scrolling itself is not cool.

lugao10 hours ago

I am not on mobile. It all boils down to the way decade old convetions/expectations are broken.

The things that look like buttons (and are spans in the html code, not even anchors!) trigger non-local transitions (the left panel thing) when hovered... and they close the opened panel when clicked, so if I move my mouse to click on it the end result is a panel that flashes.

I need to keep ignoring the usual button affordance of being clicked and force myself to think they are tiggered on hover.

If this isn't bad UX I don't kown what it is.

zote10 hours ago

While you're here the little colored buttons, that expand to show more info are neat (note the first one in this article has template text at the moment) ; and when they expand and highlight the text with color they can clip other nearby text

nkozyra10 hours ago

I think you can look at UX like this less like a web page and more like a presentation. In that framing it's more palatable.

In general we consume blogs more like traditional web pages, so it feels ... "wrong," but in some ways it keeps all of the content at hand and lets you navigate linearly or back and forth pretty reasonably, the way you might traverse a PPT.

meowface10 hours ago

I'm sorry but anything that hijacks the scrollbar in any way is just a no-go. You have to not interfere with scrolling. (Taking some other action on the page during scrolling can be okay, but actually affecting the scrolling itself in any way while you are scrolling should be verboten, in my opinion.)

matser10 hours ago

Lenis.js (smooth scrolling lib) was actually implemented for some technical reason that is no longer required; so might actually remove it indeed.

Sohcahtoa829 hours ago

Pages interfering with how scrolling works infuriates me so much that I've often considered writing an extension that tries to disable that behavior, or even compile my own Firefox if I had to.

encom4 hours ago

I hope you do. And while you're at it, make it so websites are no longer able to fuck with the scrollbar in any way whatsoever, including but not limited to changing its size or colour.

hn_is_all_bots6 hours ago

[flagged]