* . *
  • About
  • Advertise
  • Privacy & Policy
  • Contact
Tuesday, January 6, 2026
Earth-News
  • Home
  • Business
  • Entertainment

    Chesterfield event makes national news, USA TODAY 10BEST list – The Progress Index

    Stunning Moments Captured at the Critics Choice Awards

    FNC Entertainment Stock Soars as CNBLUE Drops New Single and Unveils Thrilling 2025 Plans

    Eddie Murphy Opens Up About Leaving the Oscars Early After ‘Dreamgirls’ Loss

    Andree Verleger Celebrated as Top Entertainment Consultant and Visionary of the Year

    New Film The Plague Turns Tween Bullying into a Gripping Drama

  • General
  • Health
  • News

    Cracking the Code: Why China’s Economic Challenges Aren’t Shaking Markets, Unlike America’s” – Bloomberg

    Trump’s Narrow Window to Spread the Truth About Harris

    Trump’s Narrow Window to Spread the Truth About Harris

    Israel-Gaza war live updates: Hamas leader Ismail Haniyeh assassinated in Iran, group says

    Israel-Gaza war live updates: Hamas leader Ismail Haniyeh assassinated in Iran, group says

    PAP Boss to Niger Delta Youths, Stay Away from the Protest

    PAP Boss to Niger Delta Youths, Stay Away from the Protest

    Court Restricts Protests In Lagos To Freedom, Peace Park

    Court Restricts Protests In Lagos To Freedom, Peace Park

    Fans React to Jazz Jennings’ Inspiring Weight Loss Journey

    Fans React to Jazz Jennings’ Inspiring Weight Loss Journey

    Trending Tags

    • Trump Inauguration
    • United Stated
    • White House
    • Market Stories
    • Election Results
  • Science
  • Sports
  • Technology

    Seed Companies Can Now Purchase PowerPollen Pollination Technology Integrated on Oxbo Power Units Through Exclusive Partnership – AgNewsWire

    West Virginia Junior College Launches Exciting New Radiologic Technology Program

    ASUS Republic of Gamers Unveils Next-Gen RGB OLED Technology at CES 2026

    Cedar Grove Dominates in Thrilling Boys Basketball Showdown

    Bombshell’: A Gripping Cautionary Tale About Technology’s Impact

    How Proactive Technology Transforms Extended Households from Strain to Stability

    Trending Tags

    • Nintendo Switch
    • CES 2017
    • Playstation 4 Pro
    • Mark Zuckerberg
No Result
View All Result
  • Home
  • Business
  • Entertainment

    Chesterfield event makes national news, USA TODAY 10BEST list – The Progress Index

    Stunning Moments Captured at the Critics Choice Awards

    FNC Entertainment Stock Soars as CNBLUE Drops New Single and Unveils Thrilling 2025 Plans

    Eddie Murphy Opens Up About Leaving the Oscars Early After ‘Dreamgirls’ Loss

    Andree Verleger Celebrated as Top Entertainment Consultant and Visionary of the Year

    New Film The Plague Turns Tween Bullying into a Gripping Drama

  • General
  • Health
  • News

    Cracking the Code: Why China’s Economic Challenges Aren’t Shaking Markets, Unlike America’s” – Bloomberg

    Trump’s Narrow Window to Spread the Truth About Harris

    Trump’s Narrow Window to Spread the Truth About Harris

    Israel-Gaza war live updates: Hamas leader Ismail Haniyeh assassinated in Iran, group says

    Israel-Gaza war live updates: Hamas leader Ismail Haniyeh assassinated in Iran, group says

    PAP Boss to Niger Delta Youths, Stay Away from the Protest

    PAP Boss to Niger Delta Youths, Stay Away from the Protest

    Court Restricts Protests In Lagos To Freedom, Peace Park

    Court Restricts Protests In Lagos To Freedom, Peace Park

    Fans React to Jazz Jennings’ Inspiring Weight Loss Journey

    Fans React to Jazz Jennings’ Inspiring Weight Loss Journey

    Trending Tags

    • Trump Inauguration
    • United Stated
    • White House
    • Market Stories
    • Election Results
  • Science
  • Sports
  • Technology

    Seed Companies Can Now Purchase PowerPollen Pollination Technology Integrated on Oxbo Power Units Through Exclusive Partnership – AgNewsWire

    West Virginia Junior College Launches Exciting New Radiologic Technology Program

    ASUS Republic of Gamers Unveils Next-Gen RGB OLED Technology at CES 2026

    Cedar Grove Dominates in Thrilling Boys Basketball Showdown

    Bombshell’: A Gripping Cautionary Tale About Technology’s Impact

    How Proactive Technology Transforms Extended Households from Strain to Stability

    Trending Tags

    • Nintendo Switch
    • CES 2017
    • Playstation 4 Pro
    • Mark Zuckerberg
No Result
View All Result
Earth-News
No Result
View All Result
Home Technology

Show HN: A JavaScript UI library for imperative JSX

July 6, 2024
in Technology
Show HN: A JavaScript UI library for imperative JSX
Share on FacebookShare on Twitter

A web framework for imperative JSX – a new way to think about UI engineering.

I initially created this for the Matry editor,
but I saw that it could be generally useful, so I’m releasing it under the MIT license.
Right now it’s brand new, under active development, and pretty under-powered.
Do not use it in production until it reaches v1.0.0.

To see examples of it in action, I’ve created a repo with recipes

I love React, but it has issues:

The diffing behavior can be conceptually difficult to understand
It can be awkward to work with inherently imperative constructs such as setTimeout and autofocus

Context, hooks, and signals are all required to pass state around the UI tree
The structure of your application state ends up being shaped by the UI, when it should be the other way around
React takes total control over anything in its tree, meaning most UI packages must have React-specific integrations to work correctly
Getting React to work with SSR has caused lots of headaches
It creates a barrier between the developer and the DOM, leading to a generation of devs missing out on core platform features
There’s a ceiling to how performant a React application can be, and maximizing performance requires deep understanding of React’s rendering model
Because of React’s one-way data flow, there are no built-in features for reading the state of the UI

If we accept the fact that the web is inherently imperative,
then I believe we can resolve most if not all of the above problems.
We don’t need to throw the baby out with the bathwater though, because JSX is fantastic.

Matry exposes a handful of simple, standalone functions that allow you to use JSX to imperatively create and update the DOM.
This is a significant departure from how JSX is traditionally used,
but the benefit of this approach is that your UI remains declarative,
while your business logic remains imperative.
This means no more hooks, no more context, no more prop drilling.

Below are the functions provided by @matry/dom:

Replace – replaces one or more elements’ children

Append – appends new elements

Remove – removes elements

Swap – swaps two elements

Set Content – sets the text content of one or more elements

Set Attributes – sets attributes of one or more elements

Remove Attributes – removes attributes from one or more elements

Add Event Listeners – adds event listeners to one or more elements

Remove Event Listeners – removes event listeners from one or more elements

Below is a simple counter demo.

My Counter App

// set our initial value
let count=0;

// perform our initial render
replace(

The count is {count}
add 1

);

// replace the text content
function add() {
count++;
setContent(The count is {count});
}

In the above example,
we call replace to render our UI into the main element.
Then we use setContent to update the content of the p element.
Notice when updating the DOM, we only need to pass in just enough JSX to identify which elements we want to modify.
This puts you in complete control of your apps performance.

As with all technology, there are advantages and disadvantages of this approach.
In the interest of being transparent, I’ll list the disadvantages first.

Since JSX is acting as a query, the queries have limited expressive power. For instance, in order to match against a node in the DOM, it must be an exact match, i.e. there can be no “contains” queries as it would introduce too many edge cases.
There will be duplication of html content, at least in terms of code. While this can be reduced by various strategies, it’s kind of unavoidable.
You have to really think about the UI, which is something you may not be used to if you’re used to React. I’d argue this is a good thing, but it won’t be everyone’s cup of tea.
It doesn’t define how you procure your state, whereas React tends to be a bit more opinionated. This can lead to more architectural work needed for developers. I’d again argue this is a net good, but you can decide for yourself whether this is something you want.

You have complete control over the rendering process, and can make Matry applications as performant as you want.
Matry doesn’t “own” the UI you pass to JSX, so you can easily use common libraries (e.g. the Google Maps SDK) without worry. Heck, you can even render to the html, head, and body elements!
The functions offered by Matry – write(), append(), setAttributes() and others – are mirror counterparts to native DOM methods, meaning you can think about the platform. There’s no such thing as “thinking in Matry”, it’s just “thinking in the web.”
Unlike React, Matry is truly a “UI library.” It has no side effects that require you to structure your code or your data in any particular way.

First, install the package.
Vite is recommended, mostly because that’s what I’ve used to test it with :p

npm create vite whatever # choose Vanilla, then JavaScript (for now)
cd whatever
npm install @matry/dom

Next, configure Vite so that you can use Matry’s JSX runtime:

// vite.config.js
import { defineConfig } from “vite”;

export default defineConfig({
esbuild: {
jsx: “transform”,
jsxDev: false,
jsxInject: `import { jsx } from ‘@matry/dom’`,
jsxFactory: “jsx.component”,
},
});

Voila! You’re good to go!

Matry should not be considered stable until 1.0.0,
so do not use it in production until then.
There are lots of features yet to be implemented – stay tuned!

Some things I have planned for the library:

TypeScript support

reverse() for reversing lists of elements

paint() for updating the CSSOM

serialize() for rendering JSX to a string (primarily for SSR)

deserialize() for rendering a string (will be used in respones from SSR updates)

read() for loading data from static html into JS memory

>>> Read full article>>>
Copyright for syndicated content belongs to the linked Source : Hacker News – https://www.npmjs.com/package/@matry/dom

Tags: JavaScriptlibrarytechnology
Previous Post

Hadrius (YC W23) Is Hiring Founding Engineers in NYC

Next Post

Properly testing concurrent data structures

California Cracks Down on Fake Liens with Harsher Penalties to Protect Politicians and Businesses

January 6, 2026

Uncovering Nature’s Secrets: How Unusual Otter Droppings Led to a Surprising Ecological Discovery

January 6, 2026

A NASA satellite caught a giant tsunami doing something scientists didn’t expect – ScienceDaily

January 6, 2026

Samsung’s new phone looks straight out of science fiction. I got to try it – CNN

January 6, 2026

‘Grab what you can:’ The global rush for second passports – Channel 3000

January 6, 2026

Seed Companies Can Now Purchase PowerPollen Pollination Technology Integrated on Oxbo Power Units Through Exclusive Partnership – AgNewsWire

January 6, 2026

Paula’s Choice Kicks Off 2026 with a Bold New Campaign Focused on Longevity and Sports

January 6, 2026

Japanese Star Tatsuya Imai Aims To ‘Chase a World Championship’ With Astros – FOX Sports

January 6, 2026

OpEd: Health Care Keeps Our Economy Alive – Los Angeles Business Journal

January 6, 2026

Chesterfield event makes national news, USA TODAY 10BEST list – The Progress Index

January 6, 2026

Categories

Archives

January 2026
M T W T F S S
 1234
567891011
12131415161718
19202122232425
262728293031  
« Dec    
Earth-News.info

The Earth News is an independent English-language daily published Website from all around the World News

Browse by Category

  • Business (20,132)
  • Ecology (1,008)
  • Economy (1,026)
  • Entertainment (21,902)
  • General (19,174)
  • Health (10,066)
  • Lifestyle (1,039)
  • News (22,149)
  • People (1,033)
  • Politics (1,041)
  • Science (16,242)
  • Sports (21,527)
  • Technology (16,009)
  • World (1,015)

Recent News

California Cracks Down on Fake Liens with Harsher Penalties to Protect Politicians and Businesses

January 6, 2026

Uncovering Nature’s Secrets: How Unusual Otter Droppings Led to a Surprising Ecological Discovery

January 6, 2026
  • About
  • Advertise
  • Privacy & Policy
  • Contact

© 2023 earth-news.info

No Result
View All Result

© 2023 earth-news.info

No Result
View All Result

© 2023 earth-news.info

Go to mobile version