TE
TechEcho
Home24h TopNewestBestAskShowJobs
GitHubTwitter
Home

TechEcho

A tech news platform built with Next.js, providing global tech news and discussions.

GitHubTwitter

Home

HomeNewestBestAskShowJobs

Resources

HackerNews APIOriginal HackerNewsNext.js

© 2025 TechEcho. All rights reserved.

Kill-sticky, a bookmarklet to remove sticky elements and restore scrolling

395 pointsby ivankover 2 years ago

30 comments

joostersover 2 years ago
This is my most useful bookmark, I use it everywhere (it&#x27;s even practical on an iphone)<p>So many sites have a top banner that disappears as you scroll down a page, but as soon as you scroll upwards even a little bit, it pops up again. This is immensely frustrating because I tend to read at the top of a page and scroll down as I&#x27;m reading. So if I scroll down slightly too far and then correct myself, the banner will instantly obscure the bit of the text I&#x27;m trying to read. It&#x27;s very satisfying to be able to click on the bookmark and fix the site&#x27;s crap design!
评论 #32999612 未加载
评论 #32998963 未加载
评论 #33002486 未加载
评论 #33003360 未加载
评论 #33002637 未加载
评论 #33003045 未加载
_V_over 2 years ago
Honestly I have uBlock set in a way that blocks most of this stuff by default. I have several &quot;steps&quot; of permissivity:<p>1) (default) block all JS completely<p>2) Block 3rd party js<p>3) Permit all js (rare)<p>If the web fails to render in (1) and I do not necessarily need anything on that web I can get elsewhere, I just leave the web. F that web and F that creator. If I have to (webshop etc) I usualy just enable (2) which works most of the time. (3) is basically only for special webs like banking etc which is just PITA to debug as you have to be logging in constantly etc.<p>Websites today are just full of unnecessary crap and are downright unusable when on slower connection like 3G. Most of the webs now require your browser to download 2M of JS to have &quot;slide out menus&quot; or some other stupid stuff. uBlock is a must, because without that you will run out of data plan almost instantly.<p>And to make things worse, Chromium-based browsers will make adblocking much harder with Manifest v3. As soon as this happens, I will go to Firefox. And after that probably Links (unironically).<p>Btw spinning up a docker to shrink 1 JS function to a oneliner is perfectly capturing the essence of what&#x27;s wrong with web nowdays :-D
评论 #33005798 未加载
评论 #33003565 未加载
评论 #33005988 未加载
acabalover 2 years ago
I use this all the time, it&#x27;s invaluable. I also use it to remove sticky headers, which I find to be deeply annoying because they waste space and often break keyboard scrolling by scrolling the next few lines of text under the header.<p>In Firefox I&#x27;ve assigned it a keyword shortcut, so I can type `ctrl + l` to select the address bar, then `ks` `&lt;enter&gt;` to execute the JS without having to click.
评论 #33001822 未加载
评论 #32998641 未加载
ryandrakeover 2 years ago
I feel I&#x27;m getting close to the point where I&#x27;m just going to start disabling CSS and JS for normal web browsing, only whitelisting certain sites that 1. I have to use and 2. Simply don&#x27;t work at all without CSS&#x2F;JS. IMO browsers have abandoned their role as the &quot;user&#x27;s agent&quot; and handed over entirely too much control over style, presentation and function to web developers. The fact that you need plugins, extensions, adblocks, bookmarklets, and so on, just to regain this control should be troubling but I guess progress has to march on.<p>I know I&#x27;m in the tiny minority here and firmly in the &quot;yelling at the clouds&quot; territory, but I really wish we could go back to the simpler times of the web being hyperTEXT documents linked together and that&#x27;s it.
评论 #32999462 未加载
评论 #32999413 未加载
评论 #32999723 未加载
评论 #33000525 未加载
评论 #32999470 未加载
评论 #33000442 未加载
评论 #33002171 未加载
评论 #33000212 未加载
评论 #33002697 未加载
ryanianianover 2 years ago
Browsers were able to fight window.open popups back in the day by intercepting&#x2F;blocking the window.open API. This was, iirc, one of the killer features of firefox back in the day. But cat and mouse: websites are now abusing CSS to recreate the popup experience.<p>Bookmarklets like this are helpful (and this is a great successor), but bookmarklets are very difficult to install and use for the average internet user. I could not figure out how to install this on my iPhone without using desktop Safari to sync bookmarks.<p>Is there any hope of browsers being able to combat popup modals and other sticky gross things in an automated (and on by default) way that doesn&#x27;t totally break sites that require sticky items for navigation or other, non-hostile features?
评论 #32999633 未加载
评论 #32999652 未加载
评论 #33005832 未加载
评论 #33000493 未加载
bsimpsonover 2 years ago
It&#x27;s wild that you have to set up Docker to contribute to 600 characters of JavaScript.<p>It&#x27;s like building a robot to pass the butter.
评论 #33002270 未加载
评论 #33001768 未加载
评论 #33005340 未加载
ARandomerDudeover 2 years ago
I kill sticky elements with the back button. If a site wants to hassle me, I won&#x27;t give them attention or ad money.
评论 #32998854 未加载
评论 #33004558 未加载
userbinatorover 2 years ago
I seriously don&#x27;t understand why some people seem to like position:sticky so much. It&#x27;s really offensive when the element I&#x27;m trying to scroll out of the way refuses to leave and clings to the edge, almost mockingly.<p>I&#x27;ve had a &quot;replace sticky with relative&quot; filter in my MITM proxy since the day that CSS misfeature showed up in browsers.
评论 #33000742 未加载
评论 #33000459 未加载
baubleover 2 years ago
I used that for a while, but I was using it so often that I installed <a href="https:&#x2F;&#x2F;addons.mozilla.org&#x2F;en-US&#x2F;firefox&#x2F;addon&#x2F;alwayskillsticky&#x2F;" rel="nofollow">https:&#x2F;&#x2F;addons.mozilla.org&#x2F;en-US&#x2F;firefox&#x2F;addon&#x2F;alwayskillsti...</a>. Sometimes I see things flicker briefly into view and I&#x27;m reminded that it&#x27;s working. I&#x27;ve had to whitelist several sites that I use regularly, but it&#x27;s pretty low maintenance after that.
szhuover 2 years ago
Similar thing I made recently, but as a Chrome extension:<p><a href="https:&#x2F;&#x2F;github.com&#x2F;szhu&#x2F;pagefreeze" rel="nofollow">https:&#x2F;&#x2F;github.com&#x2F;szhu&#x2F;pagefreeze</a><p>It does the same thing, and in addition also prevents any async JS from running. It also can be easily toggled per-site; just click the extension icon! Unfortunately I didn&#x27;t have time to put a GIF in the README. OP did a better job of explaining what their project does!<p>Would love feedback on it + hope it helps someone as well!
评论 #32999657 未加载
sillysaurusxover 2 years ago
Is there a way to do this on mobile? Probably not an easy one, but if mobile Safari had an extension, I&#x27;d install it immediately.<p>The worst is when you use the top edge of the screen to read, but the site has a navbar that only shows up when you scroll up. So if you scroll slowly upwards, the navbar creeps slowly downwards, and keeps hiding the text you&#x27;re trying to read. Thankfully such design choices seem to be getting rarer.<p>Do sticky headers measurably increase conversion rates, or is it a fad? If there&#x27;s data to support why people keep making this decision, I guess I could be persuaded to feel that it&#x27;s not a case of &quot;Everyone likes to do it their way, and you like your way.&quot;
评论 #32998860 未加载
评论 #32999070 未加载
评论 #32998936 未加载
评论 #32999240 未加载
aendrukover 2 years ago
Reminder that you can also configure persistent rules to do this with your favorite wide-spectrum blocker:<p><pre><code> example.com###annoying-header:style(position: unset !important) example.com##.restrictive-box:style(overflow: unset !important)</code></pre>
评论 #32999277 未加载
1970-01-01over 2 years ago
Just wanted to thank you for making this. It&#x27;s working perfectly with Twitter.
karaterobotover 2 years ago
I spent an afternoon trying to figure out how to detect when an element had its display or transform properties changed when it was also the full size of the screen. This was my proposed heuristic for deciding when something was a full screen popup, in the process of taking over your window. The idea would be to zap these elements when they were triggered, so that you&#x27;d not have to encounter them in the first place.<p>Cool story huh? Anyway, that never went anywhere, but I&#x27;d donate to an open source project if a better programmer than me wanted to take on this noble struggle.
cercatrovaover 2 years ago
I use this often. However I sometimes want the sticky part to stay where it initially rendered on the page, like a nav bar. Perhaps I don&#x27;t know enough CSS but anyone know how I can do that?
评论 #33000138 未加载
评论 #32998895 未加载
评论 #32998438 未加载
Night_Thastusover 2 years ago
Fantastic. Making the web a less awful place, one workaround at a time. You&#x27;ve got my bookmark.<p>Now, make an auto-detect for this and stick it into something like uBlockOrigin and we&#x27;re golden. :)
autoexecover 2 years ago
I use an addon called &quot;nuke anything&quot; that lets you right click and remove pretty much anything (only until the page is reloaded). It&#x27;s a lifesaver when you browse with JS disabled since that can cause pages to display poorly (menus spewed all over the screen for example) but it comes in handy a lot for sticky elements. I have seen a few sites that manage to prevent certain things from being selected though. It&#x27;s nice to have yet another tool to fall back on if I need it.
评论 #32999949 未加载
tempodoxover 2 years ago
I find this very useful.<p>On Unix, when you have Node.js installed, you can avoid the Docker overhead for creation of a bookmarklet from a JS file with a shell script like this:<p><pre><code> cat &#x27;kill-sticky.js&#x27; \ | tr -s &#x27;\011\012\015\040&#x27; &#x27;\040&#x27; \ | node -e &#x27;console.log(`javascript:${encodeURIComponent(fs.readFileSync(process.stdin.fd).toString())}`)&#x27; </code></pre> Insert the output as your bookmarklet&#x27;s URL.
sorenjanover 2 years ago
I sometimes end up on pages that I can&#x27;t scroll. It turns out some pages show a sticky div with a cookie consent dialog, and uBlock has removed it but left the overflow: hidden on the body tag that the site owner found necessary to put there until I click on the now removed div for some reason.
marcodiegoover 2 years ago
I have this addon: <a href="https:&#x2F;&#x2F;addons.mozilla.org&#x2F;en-US&#x2F;firefox&#x2F;addon&#x2F;kill-sticky&#x2F;" rel="nofollow">https:&#x2F;&#x2F;addons.mozilla.org&#x2F;en-US&#x2F;firefox&#x2F;addon&#x2F;kill-sticky&#x2F;</a> installed on Firefox. Use it more than I&#x27;d like.
fisherjeffover 2 years ago
Ha, wow, I wrote my own (much less fancy) bookmarklet that does this and also called it Kill Sticky:<p>javascript:for(e%20of%20document.querySelectorAll(%22body%20*%22))%7Bp=getComputedStyle(e).position;if((p===%22fixed%22)%7C%7C(~p.indexOf(%22sticky%22)))e.parentNode.removeChild(e);%7D
评论 #32999340 未加载
axioliteover 2 years ago
Unfortunately, bookmarklets don&#x27;t work on Firefox mobile. Fortunately however, the &quot;Hide Fixed Elements&quot; and &quot;Scroll Everywhere&quot; add-ons <i>do</i> work on mobile:<p><a href="https:&#x2F;&#x2F;addons.mozilla.org&#x2F;en-US&#x2F;firefox&#x2F;addon&#x2F;hide-fixed-elements&#x2F;" rel="nofollow">https:&#x2F;&#x2F;addons.mozilla.org&#x2F;en-US&#x2F;firefox&#x2F;addon&#x2F;hide-fixed-el...</a><p><a href="https:&#x2F;&#x2F;addons.mozilla.org&#x2F;en-US&#x2F;firefox&#x2F;addon&#x2F;scroll-everywhere&#x2F;" rel="nofollow">https:&#x2F;&#x2F;addons.mozilla.org&#x2F;en-US&#x2F;firefox&#x2F;addon&#x2F;scroll-everyw...</a><p>That is, if you jump through the hoops to make more than the default 8 add-ons available on Firefox mobile:<p><a href="https:&#x2F;&#x2F;blog.mozilla.org&#x2F;addons&#x2F;2020&#x2F;09&#x2F;29&#x2F;expanded-extension-support-in-firefox-for-android-nightly&#x2F;" rel="nofollow">https:&#x2F;&#x2F;blog.mozilla.org&#x2F;addons&#x2F;2020&#x2F;09&#x2F;29&#x2F;expanded-extensio...</a>
评论 #33003076 未加载
评论 #33000582 未加载
评论 #33003938 未加载
Yizahiover 2 years ago
Tried this script on a handful of different websites - news, tech, forums, reddit. In 100% of cases this scripts nukes top header completely, leaving me without navbar or menu. So it is a very enticing tool, but unfortunately not usable.
curlftpfsover 2 years ago
&gt; Set the style of the html node for overflow: auto<p>I have a custom style to do this for ALL sites, warning:<p>1. it can break websites in unexpected ways<p>2. There&#x27;s often a class on the &lt;body&gt; hiding overflow that needs to be overwritten instead&#x2F;as well
vmooreover 2 years ago
You could pass this code into Tampermonkey&#x2F;Violentmonkey[0] and use it globally on every domain.<p>[0] <a href="https:&#x2F;&#x2F;violentmonkey.github.io&#x2F;" rel="nofollow">https:&#x2F;&#x2F;violentmonkey.github.io&#x2F;</a>
vlunkrover 2 years ago
Sticky positioning on mobile devices is rarely a good experience. (Though it might be my tiny phone screen.) I would love for it to get special treatment on mobile so it could always be dismissed or something.
alphabet9000over 2 years ago
i wish there was a way, with CSS only, to specifically target existing css rules, and have one rule change to another rule, globally. for instance, something like: [position:fixed] { position:relative }. i.e. that is different than * { position:relative }, because it doesn&#x27;t apply position:relative to everything, it only changes position:fixed to position:relative.
sf_robover 2 years ago
Is there a purpose built bookmarklet searchable repository anywhere like there are for extensions&#x2F;addons?
sp332over 2 years ago
Is there something that will prevent Medium pages from scrolling to the top when you reload the page?
评论 #33002845 未加载
jerrygoyalover 2 years ago
People who are using some other bookmarklets, could you share so others can benefit as well?
评论 #33020601 未加载