惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
G
GRAHAM CLULEY
P
Privacy & Cybersecurity Law Blog
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
宝玉的分享
宝玉的分享
P
Proofpoint News Feed
H
Help Net Security
V
Visual Studio Blog
阮一峰的网络日志
阮一峰的网络日志
C
Cisco Blogs
人人都是产品经理
人人都是产品经理
Know Your Adversary
Know Your Adversary
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
Recorded Future
Recorded Future
I
Intezer
罗磊的独立博客
T
The Exploit Database - CXSecurity.com
Blog — PlanetScale
Blog — PlanetScale
Malwarebytes
Malwarebytes
Spread Privacy
Spread Privacy
T
Tor Project blog
V
Vulnerabilities – Threatpost
云风的 BLOG
云风的 BLOG
腾讯CDC
B
Blog RSS Feed
Stack Overflow Blog
Stack Overflow Blog
F
Future of Privacy Forum
MyScale Blog
MyScale Blog
Latest news
Latest news
IT之家
IT之家
MongoDB | Blog
MongoDB | Blog
The Hacker News
The Hacker News
S
Securelist
博客园 - 【当耐特】
C
CXSECURITY Database RSS Feed - CXSecurity.com
T
Threat Research - Cisco Blogs
Jina AI
Jina AI
Cisco Talos Blog
Cisco Talos Blog
B
Blog
博客园 - 三生石上(FineUI控件)
Last Week in AI
Last Week in AI
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
M
MIT News - Artificial intelligence
V
V2EX
D
Darknet – Hacking Tools, Hacker News & Cyber Security
The Cloudflare Blog
The GitHub Blog
The GitHub Blog
博客园 - 聂微东
F
Full Disclosure
C
CERT Recently Published Vulnerability Notes

DEV Community

I built a CLI that eliminates README reading forever Measuring AI Gateway Failover: 30 Days of Production Data The Folly of Global AI Platforms: Or How We Built a System That Actually Works in Cameroon Week 9 The 10-Minute Race: Scaling the "Cancel Order" Button to 100K+ Requests Per Second SQL Performance: Indexing, Query Tuning & Explain Plans (Developer Guide) Tutorial: This AI Now Tells You if a Meeting Could Be an Email GitHub Is No Longer a Place for Serious Work Build an AI-Powered Developer Portal with Backstage and .NET Updates to developer experience on Setapp Node.Js Express CRUD template Lint Your Phishing Templates Like You Lint Your Code From Code to Cloud: 3 Labs for Deploying Your AI Agent I built Voice2Sub: a local AI subtitle generator for video and audio The OCR Rabbit Hole Built a 100k-Document RAG System by Hand. Hermes Read the Architecture in 47 Seconds. I tried monetizing my MCP server with x402 — production needs more than npm install Understanding Tracking Dimensions in Accounting Integrations I Ran My Local, NOT AI, AI Code Auditor on Its Own Source Code Agent Surface Map: Gemma 4 review before you install an MCP Stop Being Nice, Start Being Right": The Day My User Reconfigured My Reward Function Building a Database Performance Testing Tool With AI: The Honest Breakdown Hot To Run LLMs Locally Research blockchain with post-quantum Dilithium and custom zk-STARKs from scratch AI agents do not just need tool access. They need execution control. The CTO’s Blueprint for Governing Multi-Agent AI Systems in the Enterprise I audited our CMS and 86% of our articles were invisible. A Sanity gotcha. Upselling Explained Industry-Specific Tactics for EC Owners 2026 I Keep Hermes Agent's Self-Improvement OFF For the First 14 Days — Here's What Happens When I Don't I Built the Hermes + Claude Code Dual-Stack: Orchestrator Meets Coder — Here's the Full Architecture Stop Using .iterrows(). Here's What Actually Fast Looks Like I Built a SaaS to Stop the Awkward "Hey, Did You Get My Invoice?" Conversation I Renamed a Hot Postgres Table Without Dropping a Request How to Build a Self-Hosted AI Gateway With LiteLLM and Open WebUI What is a Webhook? A Complete Guide for Beginners Headless BI: How a Universal Semantic Layer Replaces Tool-Specific Models Beyond Translation: A Developer's Guide to App Localization (i18n & l10n) Aegis: Designing an Offline Ambient Co-Working Companion for High-Burnout Medical and STEM Grinds Local LLM Code Completion Showdown: Zed AI vs Continue vs Cursor (Honest 2026 Review) The Agentic Payment Protocol Wars Your No-Code AI Agent Has a Memory Problem The Agentic Payment Protocol Wars How to Bypass LinkedIn Commercial Use Limit in 2026 (Without Paying $150/mo) We built a statechart hosting platform where two actors in the same state can migrate to different versions — here's why that matters Playwright vs TWD: A Frontend Developer's Honest Comparison Claude Code's skillListingBudgetFraction: The Undocumented Setting Silently Killing Half Your Skills O GitHub pode mudar sua carreira mais do que você imagina Just redesigned and launched my developer portfolio 🚀 Would genuinely love some honest feedback from the dev community 👨‍💻 Data Virtualization and the Semantic Layer: Query Without Copying Launching opub: donated compute for open-source maintainers Four iteration rounds on a security scanner I run, all of them visible. Here is what the loop actually looks like. Why Good Abstractions Make Debugging Harder Found a Coordinated Inauthentic Network on GitHub: 24 Accounts, Fabricated History, and a Generator That Left Its PID in Three READMEs Cursor Just Released Composer 2.5. Here's What Actually Changed for AI Coding Agents. What Wrong Docs Cost Test Automation Teams Export Your DeepSeek Chats to Word, PDF, Google Docs, Markdown & Notion in One Click When the Docs Lie OpenShift Observability: Built-in vs. Bring-Your-Own If your AI initiative is pending for 6 months, the bottleneck is probably not technology Hermes Agent Under the Hood: The Open-Source Runtime for Autonomous AI Systems Expert Systems -The AI That Existed Before AI Was Cool AI-generated accessibility, an update — frontier models still fail, but skills change the game My HTML Learning Journey 🚀 The Day PayPal Failed and the Rust Rewrite Saved the Product Launch Google Sheets CRM: 4 Ways I've Actually Done It (with Apps Script Code) BrontoScope: AI-Powered Error Investigations The job of an AI engineer inside a 40-person company is not what most CEOs think it is Building a Clinical Speech-Therapy App With a Real SLP: 4 Lessons From PhoenixSteps 7 overlooked .Net features How Stripe Took 48 Hours and 3 API Calls to Break My Freelance Income Stream in Lagos Pretty normal Both Camps in the 'Left Behind' Argument Are Right About Each Other Flutter MCP Toolkit v3 Google Just Shipped Gemini 3.5 Flash. Here's What Developers Actually Need to Know. 🔐 Working with Private Symfony Recipes Rate limiting in web apps: what to protect before picking a library Rate limiting en aplicaciones web: qué proteger antes de elegir una librería What Are Lakehouse Catalogs? The Role of Catalogs in Apache Iceberg What It Really Takes to Become a Senior Software Engineer Microservices Were Never About Technology JS Crime Scene: The Misleading Array Project-as-code for a Directus v9 backend When the API literally burned your database after a typo COOKIES DPRK Hacking Trends 2026: AI‑Powered Supply Chain and Developer Environment Attacks Phone control for AI coding sessions is not a tiny terminal PayPal and Crypto Are Not Equals: How I Built a Gumroad Alternative for Restricted Countries Exploring Tech as a Content Writer I Raised Gemma 4's Token Cap. The Dense Model Stopped Refusing. React Server Components Don't Make Your App Fast by Default Multi-Stage Builds for a Next.js App — Reduce Image Size by 70% I Built a Chrome Extension That Teaches Vocabulary While You Browse Why I Walked Back from Next.js and RSC to a Plain SPA and a Separate Backend NeuralPocket: Private On-Device AI with Gemma 4 — Android & Web Github Speckit: Revolucionando o Desenvolvimento com SDD Cloud Cost Elasticity I Built a Payment System for Bangladesh—Heres Why Stripe Failed Us Polyglot Persistence in Microservices: Choosing the Right Database for Each Service Centralized Authentication for a Multi-Brand Laravel Ecosystem How I made a perfect recording button. Simple yet complex thing.
Why I Got Tired of Class-Heavy UI Code and Started Building Around Attributes
Drew Marshal · 2026-05-22 · via DEV Community

One thing that slowly wore me down over the years of frontend development wasn’t JavaScript.

It wasn’t components.

It wasn’t CSS itself.

It was the increasing amount of visual noise in the markup.

At some point, UI code started feeling less like structure and more like string management.

You’d open a component and see something like:

<div class="flex flex-col items-center justify-between gap-6 rounded-2xl border border-zinc-800 bg-zinc-900/50 p-8 shadow-lg backdrop-blur-md">

Enter fullscreen mode Exit fullscreen mode

And while utility-first systems absolutely solve real problems, I eventually realized something:

I was spending more time parsing styling syntax than understanding the component itself.

That started bothering me.

A lot.


I Wanted the Markup to Read Like Structure Again

Over time, I became increasingly interested in making UI code feel:

  • readable
  • semantic
  • intentional
  • composable
  • expressive

Not just:

“technically efficient.”

That thinking eventually led me toward building Juice — an attribute-driven UI system I’ve been experimenting with as part of the broader WebEngine ecosystem.

The goal wasn’t:

“replace CSS.”

And it wasn’t:

“reinvent HTML.”

It was:

“make components readable again.”


Here’s an Example

This is a pricing section component written using Juice-style attributes:

<section type="pricing" id="pricing" paddingY="roomy">
    <div container>
        <div section-header>
            <h2>Pricing That Scales With You</h2>
            <p>Start free and grow at your own pace. No hidden fees, no surprises.</p>
        </div>

        <div grid="3x1" gap="comfortable">
            <div card="pricing">

Enter fullscreen mode Exit fullscreen mode

Even before reading the implementation details, the structure is understandable.

You can visually identify:

  • sections
  • layout intent
  • spacing
  • grouping
  • component purpose

without parsing long utility chains.

That distinction matters to me.

Because I think frontend architecture should optimize for human readability just as much as browser rendering.


The Problem Wasn’t Utility Classes

To be clear:
utility-first frameworks solve legitimate problems.

They:

  • improve consistency
  • reduce CSS sprawl
  • accelerate development
  • encourage reusable spacing systems

I completely understand why they became popular.

But after building larger systems, I noticed a tradeoff emerging.

The markup itself became increasingly overloaded with implementation detail.

Eventually components started feeling visually dense.

Not structurally expressive.


Structure and Styling Started Blending Together

One thing I kept asking myself was:

“Can I quickly understand the purpose of this component?”

Not:

“Can I understand the CSS?”

But:

“Can I understand the architecture?”

That’s a different question entirely.

Because when UI systems scale, readability becomes incredibly important.

Especially when:

  • teams grow
  • components evolve
  • systems become long-lived
  • onboarding matters
  • design systems expand

The easier a component is to mentally parse, the easier it becomes to maintain over time.


I Wanted Styling to Feel More Declarative

One thing I love about attributes is that they naturally feel declarative.

Instead of:

<div class="pt-24 pb-24">

Enter fullscreen mode Exit fullscreen mode

You can express intent more directly:

<section paddingY="roomy">

Enter fullscreen mode Exit fullscreen mode

Now the component describes meaning instead of implementation detail.

That subtle difference changes how the code feels to work with.


Components Start Reading More Like Systems

As I kept experimenting with the approach, I noticed something interesting.

The markup started feeling less like:

“a pile of styled divs”

and more like:

“a structured UI language.”

For example:

<div card="pricing" featured>

Enter fullscreen mode Exit fullscreen mode

immediately communicates:

  • this is a card
  • it’s specifically a pricing card
  • it has a featured state

without needing:

  • multiple utility chains
  • conditional class merging
  • long style abstractions

The component becomes easier to reason about visually.


The Goal Was Never “Less CSS”

Ironically, this approach actually made me think more about CSS architecture.

Because now the system itself needs:

  • scalable tokens
  • predictable patterns
  • strong conventions
  • reusable layout primitives
  • intentional naming

The complexity doesn’t disappear.

It shifts downward into the design system layer instead of living directly in every component.

And personally, I think that’s a healthier separation of concerns.


I Think Modern UI Has a Readability Problem

One thing I rarely hear discussed is how mentally exhausting frontend markup can become at scale.

Not because developers are bad.

Not because frameworks are bad.

But because modern UI systems often optimize heavily for:

  • flexibility
  • speed
  • composability

while readability becomes secondary.

That tradeoff accumulates over time.

Especially in large applications.


This Isn’t About “Winning” Frontend Development

I don’t think there’s one perfect way to build UI.

And I’m not interested in framework tribalism.

Honestly, most frontend ecosystems have good ideas worth learning from.

This is more about exploring:

  • readability
  • semantic structure
  • maintainability
  • expressive architecture

and asking:

“What should UI systems feel like five years from now?”

Because I don’t think frontend architecture is finished evolving yet.

Not even close.


Why This Matters to Me

The longer I work on systems like:

  • WebEngine
  • KiwiPress
  • Juice
  • Sig.js

the more I care about creating software that:

  • scales operationally
  • stays understandable
  • remains expressive
  • reduces hidden complexity

I want components to feel approachable.

I want systems to feel intentional.

And I want markup to communicate structure clearly again.


Final Thoughts

I still appreciate utility-first systems.

I still appreciate modern frontend tooling.

But personally, I’ve found myself increasingly drawn toward UI architectures that emphasize:

  • intent
  • structure
  • readability
  • semantics
  • declarative design

Because eventually frontend code stops being just implementation.

It becomes part of the language teams use to communicate architecture to each other.

And I think that language matters more than we sometimes realize.