<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Alexander van Elsas</title>
    <description>The latest articles on DEV Community by Alexander van Elsas (@avanelsas).</description>
    <link>https://dev.to/avanelsas</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F3862692%2F5e74f159-9ca2-4404-8049-b700a5002d21.jpeg</url>
      <title>DEV Community: Alexander van Elsas</title>
      <link>https://dev.to/avanelsas</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/avanelsas"/>
    <language>en</language>
    <item>
      <title>BareDOM: 67 Zero-Dependency Web Components (Built with CLJS)</title>
      <dc:creator>Alexander van Elsas</dc:creator>
      <pubDate>Sun, 05 Apr 2026 19:48:29 +0000</pubDate>
      <link>https://dev.to/avanelsas/baredom-67-zero-dependency-web-components-built-with-cljs-2n1i</link>
      <guid>https://dev.to/avanelsas/baredom-67-zero-dependency-web-components-built-with-cljs-2n1i</guid>
      <description>&lt;p&gt;Like most ClojureScript developers, I started building UIs with Reagent and Re-frame. They're great tools. But as my UIs grew larger and more complex, I kept rebuilding the same generic components from scratch. Bundle sizes crept up. Framework lock-in felt heavier with each project.&lt;/p&gt;

&lt;p&gt;I started looking for a different approach and discovered Web Components. Native. Framework-free. Works anywhere HTML works. I built a few by hand, but never had the spare time to develop a full set.&lt;/p&gt;

&lt;p&gt;While experimenting with Claude Code, I realised that 1 + 1 could be 3. That's how &lt;strong&gt;BareDOM&lt;/strong&gt; was born — my first open-source project.&lt;/p&gt;

&lt;h2&gt;
  
  
  What is BareDOM?
&lt;/h2&gt;

&lt;p&gt;BareDOM is a library of &lt;strong&gt;67 UI components&lt;/strong&gt; built entirely on web standards — Custom Elements v1, Shadow DOM, and ES modules. No framework runtime. No virtual DOM. No peer dependencies.&lt;/p&gt;

&lt;p&gt;The rendering model is deliberately simple:&lt;/p&gt;

&lt;p&gt;DOM = f(attributes, properties)&lt;/p&gt;

&lt;p&gt;Components are &lt;strong&gt;stateless&lt;/strong&gt;. Set an attribute, the DOM updates. Remove it, it updates back. No hidden reactive systems, no signals, no state management to learn.&lt;/p&gt;

&lt;p&gt;It's authored in ClojureScript and compiled to optimised ES modules using Google Closure's advanced compilation. But you don't need to know ClojureScript to use it — it's just HTML elements.&lt;/p&gt;

&lt;h2&gt;
  
  
  See it live
&lt;/h2&gt;

&lt;p&gt;Browse all 67 components with interactive demos:&lt;/p&gt;

&lt;p&gt;👉 &lt;a href="https://avanelsas.github.io/baredom/" rel="noopener noreferrer"&gt;https://avanelsas.github.io/baredom/&lt;/a&gt;&lt;/p&gt;

&lt;h2&gt;
  
  
  What's in the box?
&lt;/h2&gt;

&lt;p&gt;&lt;strong&gt;Form:&lt;/strong&gt; button, checkbox, switch, slider, select, date-picker, search-field, text-area, and more&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Feedback:&lt;/strong&gt; alert, badge, toast, notification-center, progress, spinner, skeleton&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Navigation:&lt;/strong&gt; navbar, sidebar, tabs, breadcrumbs, pagination, menu&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Layout:&lt;/strong&gt; card, grid, container, collapse, divider, spacer&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Data:&lt;/strong&gt; table, chart, timeline, avatar, stat&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Overlay:&lt;/strong&gt; modal, drawer, dropdown, popover, command-palette, context-menu&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Visual/Animation:&lt;/strong&gt; scroll-parallax, scroll-story, kinetic-typography, ripple-effect, organic-shape, gaussian-blur&lt;/p&gt;

&lt;h2&gt;
  
  
  How to use it
&lt;/h2&gt;

&lt;p&gt;No build tool? No problem. Drop this into any HTML page:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight html"&gt;&lt;code&gt;&lt;span class="nt"&gt;&amp;lt;script &lt;/span&gt;&lt;span class="na"&gt;type=&lt;/span&gt;&lt;span class="s"&gt;"module"&lt;/span&gt;&lt;span class="nt"&gt;&amp;gt;&lt;/span&gt;
  &lt;span class="k"&gt;import&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="nx"&gt;init&lt;/span&gt; &lt;span class="p"&gt;}&lt;/span&gt; &lt;span class="k"&gt;from&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;./dist/x-button.js&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
  &lt;span class="nf"&gt;init&lt;/span&gt;&lt;span class="p"&gt;();&lt;/span&gt;
&lt;span class="nt"&gt;&amp;lt;/script&amp;gt;&lt;/span&gt;

&lt;span class="nt"&gt;&amp;lt;x-button&lt;/span&gt; &lt;span class="na"&gt;variant=&lt;/span&gt;&lt;span class="s"&gt;"primary"&lt;/span&gt; &lt;span class="na"&gt;size=&lt;/span&gt;&lt;span class="s"&gt;"md"&lt;/span&gt;&lt;span class="nt"&gt;&amp;gt;&lt;/span&gt;Click me&lt;span class="nt"&gt;&amp;lt;/x-button&amp;gt;&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;That's it. A script tag and an HTML element. The browser loads only the modules you import.&lt;/p&gt;

&lt;h2&gt;
  
  
  Prefer npm? That works too:
&lt;/h2&gt;

&lt;p&gt;npm install @vanelsas/baredom&lt;/p&gt;

&lt;p&gt;import { init } from '@vanelsas/baredom/x-button';&lt;br&gt;
init();&lt;/p&gt;

&lt;p&gt;No framework setup, no providers, no config. Works in vanilla JS, React, Vue, Svelte, Angular, or a static page.&lt;/p&gt;

&lt;h2&gt;
  
  
  Key features
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;Zero runtime — no framework overhead, just native custom elements&lt;/li&gt;
&lt;li&gt;Tree-shakeable — each component is a separate ES module, import only what you need&lt;/li&gt;
&lt;li&gt;Full theming — every visual property exposed as CSS custom properties (--x-button-bg, etc.)&lt;/li&gt;
&lt;li&gt;Dark mode built-in — all components adapt to prefers-color-scheme automatically&lt;/li&gt;
&lt;li&gt;Accessibility included — ARIA roles, keyboard navigation, focus management, reduced motion support&lt;/li&gt;
&lt;li&gt;Open Shadow DOM — inspectable, styleable via ::part(), testable with standard APIs&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Links
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;&lt;a href="https://github.com/avanelsas/baredom" rel="noopener noreferrer"&gt;https://github.com/avanelsas/baredom&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://www.npmjs.com/package/@vanelsas/baredom" rel="noopener noreferrer"&gt;https://www.npmjs.com/package/@vanelsas/baredom&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://github.com/avanelsas/baredom/blob/main/docs/javascript-guide.md" rel="noopener noreferrer"&gt;https://github.com/avanelsas/baredom/blob/main/docs/javascript-guide.md&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://avanelsas.github.io/baredom/" rel="noopener noreferrer"&gt;https://avanelsas.github.io/baredom/&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  What's next?
&lt;/h2&gt;

&lt;p&gt;I'd love feedback from both JavaScript and ClojureScript developers. Try a component, file an issue, or just tell me what you think. The current version is v1.2.0 — more components and refinements are coming.&lt;/p&gt;

&lt;p&gt;BareDOM is MIT licensed and open source.&lt;/p&gt;

</description>
      <category>webcomponents</category>
      <category>javascript</category>
      <category>opensource</category>
      <category>showdev</category>
    </item>
  </channel>
</rss>
