DEV Community πŸ‘©β€πŸ’»πŸ‘¨β€πŸ’»

Cover image for A Typewriter, but with no HTML, CSS, or JS?!
Timothy Foster
Timothy Foster

Posted on • Updated on

A Typewriter, but with no HTML, CSS, or JS?!

Apparently a battle of sorts has erupted amongst devs clamoring for the title of Best Typewriter Animator Person.

In the classic spirit of one-uppery that has arisen, it was only a matter of time before someone, somewhere took on the most legendary of tasks: to create a typewriter animation for the web without using anything. No Javascript. No CSS. Not even HTML.

Behold, the power of Scalable Vector Graphics.

Ok but actually don't use this if you want a typewriter animation! It's got browser compatibility and accessibility issues, but at least it's a cute experiment.

How it works

The SVG spec has something called Synchronized Multimedia Integration Language (SMIL) which allows animations to be defined in the XML document directly.

For example, consider the animate tag. When made a child of some shape like rect, you can choose what attribute to animate over time and specify the way in which it changes.

So for example, the text cursor is given a simple blink animation just by adjusting the width of a rectangle between 0 and 1, and doing it discretely so it blinks:

<rect fill="black" x="0" y="4" width="1" height="12">
  <animate
    attributeName="width"
    calcMode="discrete"
    values="1; 0"
    dur="1s"
    repeatCount="indefinite" />
</rect>
Enter fullscreen mode Exit fullscreen mode

This is the first time I've ever used SMIL, so almost certainly someone smarter than me can find a better way than adjusting an overlaying white rectangle!

Top comments (12)

Collapse
 
alvaromontoro profile image
Alvaro Montoro

Nice πŸ™‚

Collapse
 
alvaromontoro profile image
Alvaro Montoro

Wait... No multiline? I may need to revoke the "nice" comment πŸ˜‹

But seriously, this looks really nice. Good entry. And welcome to the "fight."

Collapse
 
auroratide profile image
Timothy Foster Author

Lol, no multiline, hardcoded magic numbers, and the background has to be white! Truly the height of flexible code πŸ˜†

Collapse
 
afif profile image
Temani Afif • Edited on

oh, a new warrior!

PS: add some tags to your post to get some visibility (the #webdev and even #html can fit, also #codepen and the #SVG of course)

Collapse
 
auroratide profile image
Timothy Foster Author

Thanks! Totally forgot to do that ^^'

Collapse
 
thumbone profile image
Bernd Wechner

Nice. I like.

But I think it a tad extreme to claim no HTML. I mean the svg tag is... er, HTML, not?

Collapse
 
_hs_ profile image
HS

It's SchrΓΆdinger's tag. It's HTML and it's not. It's markup not HTML but HTML "supports" it. So if browser supports it while rendering it's HTML. But not really. I think you see how this could be series of blog posts by itself.

Collapse
 
auroratide profile image
Timothy Foster Author

Technically, there's a clause in the HTML spec for the svg element; but, you could also save this as a literal *.svg file and load it up in a browser, hence HTML isn't necessary!

Or a different way of putting it, I technically used HTML to present it in this post, but only used features provided by the SVG specification 😊

Collapse
 
coolscratcher profile image
CoolScratcher

Nah, that's considered SVG as it's present within an SVG file anyways I believe

Collapse
 
grahamthedev profile image
GrahamTheDev

Even my sacred SVG isn’t safe from people beating me to the punch.

Just so you know Temani normally needs a health warning on SVG stuff as the lack of CSS causes him pain! 🀣

Collapse
 
darkwiiplayer profile image
π’Š©Wii πŸ’–πŸ’›πŸ’šπŸ’™πŸ’œπŸ’πŸ’Ÿ

Ah, SVG, very nice! It's probably one of the most underappreciated technologies on the web :D

Collapse
 
brandonmcconnell profile image
Brandon McConnell

I created a CSS-only (no HTML or JS) typewriter 2Β½ years ago and feel it’s worth a mention… πŸ‘€
twitter.com/branmcconnell/status/1...

🌚 Friends don't let friends browse without dark mode.

Good news! You can update to dark mode in your DEV settings.