It's been a long road to get here. It's been so long I can't even remember when I started. I logged on to an old private Bitbucket Repo and found "initial commit" on a repo aptly named "framework" from August 21st 2016. But I'm pretty sure that was my second prototype of a Reactive JavaScript Framework that would eventually become SolidJS.
So I can safely say a stable release has been 1000s of hours and at least 5 years in the making. But I'm sure the commenters on Reddit/HN won't even read this far before getting in with "Another day, another new JavaScript Framework". Seriously, don't let me down. I keep a scorecard.
What is Solid?
It's a JavaScript framework, like React or Svelte. What makes it unique is that it flies in the face conventional knowledge to deliver what many have said to be impossible.
A reactive and precompiled "Virtual DOM"-less JSX framework with all the flexibility of React and simple mental model of Svelte.
A framework that values the explicity and composability of declarative JavaScript while staying close to the metal of the underlying DOM. It marries high level and low level abstractions. Simply put, it is anything that you want it to be.
A few people have suggested that Solid is the future.
But it is also firmly rooted in the past when JavaScript Frameworks were simpler and you had real DOM nodes at your finger tips.
When your JSX elements are just real DOM nodes:
const myButton = <button
  onClick={() => console.log("Hello")}
>Click Me</button>
// myButton instanceof HTMLButtonElement
When your control flows are runtime JavaScript:
<div>{ showComponent() && <MyComp /> }</div>
// custom end user created component
<Paginated
  list={someList()}
  numberOfItems={25}
>
  {item => <div>{item.description}</div>}
</Paginated>
When you can compose and build your primitives how you want:
function App() {
  const [count, setCount] = createSignal(0);
  // custom primitive with same syntax
  const [state, setState] = createTweenState(0);
  createEffect(() => {
    // no need for that dependency list we know when you update
    const c = count();
    // yep I'm nested
    createEffect(() => {
      document.title = `Weird Sum ${ c + state() }`;
    })
  });
  // Did I mention no stale closures to worry about?
  // Our component only runs once
  const t = setInterval(() => setCount(count() + 1, 5000);
  onCleanup(() => clearInterval(t));
  // other stuff...
}
Well, you feel like you are cheating. And not just at benchmarks😇. You are not supposed to get your cake and eat it too. Full TypeScript support. A wonderful Vite starter template. All the modern tooling and IDE support you get for free by using JSX.
Why you should be excited
It isn't just the amazing developer experience. Solid is fully featured.
Powerful Primitives
Solid is built on the back of simple general purpose Reactive primitives. Solid embraces this like no Framework before having its very renderer built entirely of the same primitives you use to build your App. After all, are these really any different?
const el = <div>Initial Text</div>
createEffect(() => {
  el.textContent = getNewText();
});
// versus
render(() => <MyGiantApp />, document.getElementById("app"))
Every part of Solid is extensible because every part could be developed in user land. You get the high level abstractions that make you productive but you don't need to leave them to get low level capabilities people enjoyed back when jQuery was king.
Solid has a compiler but it's there to help you not limit you. You can compose behaviors everywhere and use the same primitives. It's all one syntax.
Solid has even brought Directives to JSX.
// directive using the same primitives
function accordion(node, isOpen) {
  let initialHeight;
  createEffect(() => {
    if (!initialHeight) {
      initialHeight = `${node.offsetHeight}px`;
    }
    node.style.height = isOpen() ? initialHeight : 0;
  })
}
// use it like this
<div use:accordion={isOpen()}>
  {/* some expandable content */}
</div>
Sophisticated Stores
Since Solid will likely never have React compatibility it is important to integrate well with the ecosystem that is already there.
Stores both bring an easy in-house method of state management and bring Solid's pinpoint updates to solutions you might already be familiar with like Redux and XState.
Stores use nested proxies, with opt in diffing for immutable data, that lets you update one atom of data and only have those specific parts of the view update. Not re-rendering Components, but literally updating the DOM elements in place.
No need for memoized selectors, it works and it works well.
Next Generation Features
Solid has all the next generation features. How about Concurrent Rendering, and Transitions to start?
We've spent the last 2 years developing out a Suspense on the server with Streaming Server-Side Rendering and Progressive Hydration. This setup works amazingly well even when deployed to a Cloudflare Worker.
Best in Class Performance
I was going to let this one go as people get tired of hearing it. After all, this news is several years old at this point.
Solid is the fastest(and often the smallest) JavaScript Framework in the browser and on the server. I won't bore you with the details you can read about it elsewhere.
But we did a survey recently and it seems our users are happy with our performance as well.
Who voted 1? There was more than one of you.
What's Next
1.0 represents stability and commitment to quality, but there is a lot more yet to do. We are working on Solid Start a Vite-based Isomorphic Starter that has all the best practices and Server rendering built in, with the ability to deploy to multiple platforms.
We are also excited to work with Astro. Work has already begun on an integration. There are so many great build tools out there right now and new ways to leverage frameworks like ours. This is a really exciting time.
And while I started this alone 5 years ago. I'm hardly alone now. It is only through the dedicated work of the community that we have a REPL, countless 3rd party libraries to handle everything from drag and drop and animations, to Custom Elements that render 3D scenes.
Solid has been seeing adoption in tooling for IDEs with work being done on Atom and serving as the engine behind Glue Codes. And an early adopter(and perhaps influencer) of Builder.io's JSX-Lite.
Honestly, there are too many people to thank. Those that have come and gone but left a mark. From the early adopters who said encouraging words in our original Spectrum channel that kept me motivated, to the growing team of ecosystem collaborators and core maintainers. A project like this is dead in the water without others believing in it. So you have my deepest thanks.
But I do want to take a moment to make special shoutout to @adamhaile, the creator of S.js and Surplus.js who developed the initial core technology approach used in Solid. It was his research that made this possible and gave me direction to continue to push boundaries.
There is a lot more to do. But in the meanwhile, check out our website, solidjs.com with docs, examples and 40 new tutorials. And come and say hi on our Discord. It's never been easier to get started with Solid.
 
 
              

 
    
Latest comments (44)
Congratulations on the milestone! You definitely went the extra miles to deliver something very polished, feature-complete and well-documented. Great work.
If I'm being honest though, I am hot and cold on the approach. Mainly because this does not appear to have JavaScript semantics.
I look at the code examples and think, "this can't possibly work" - and obviously, if this were "just JavaScript", it couldn't. I look at the examples and the compiled output, and it looks complicated - to the point that it's not obvious to me how or why this works.
I don't really want to learn the innards of a compiler, and I expect most of the people who will be drawn to this won't want to know and don't care either. Like Vue or Angular, for most people, this will probably be a black box that you have to trust without really understanding how it works.
That's not meant as a criticism per se. There are obviously frameworks that greatly succeed under the same conditions, and this definitely fills a different space than Vue or Angular, avoiding custom syntax and leveraging the developer's existing knowledge of JavaScript. With that one caveat... that it doesn't really work like JavaScript.
Most people won't care, and there's a good chance this framework will be a success. But for me, personally, I don't like using something I can't explain. The traditional JSX transform is very easy to explain, but this is probably as difficult to explain as, say, Svelte, and feels confounding to me, much like Svelte.
I welcome this framework to the crop, but I hope there is still room in the future for frameworks that achieve reactivity without a compile step - something more like Sinuous, but with the S.js magic made more explicit. I know there are ergonomic trade-offs to something like that, and Solid syntax is definitely very visually appealing and feels familiar to React.
For me, personally, I continue to wish for something that achieves reactivity within the confines of JavaScript semantics.
I mean Sinuous started as a fork of the HyperScript version of Solid. You can use Solid exactly the same way. I just strongly don't recommend using Solid that way. You pay the cost not only in ergonomics, but in performance and size. Sinuous has done work to mitigate the latter but it comes at cost of the first 2.
Unfortunately Im not sure without creating a language for it that you can make reactivity cleaner. That was my goal initially to see if reactivity could be reduced to a point where it had a simple onboarding but all the depth to do what is needed. I decided templating was the awkward part. More potential work on compiled DSLs could maybe take this further but I fear it won't satisfy your goal.
When comparing Solid and Sinuous, the only real concern for me is ergonomics. When it comes to performance and size, they are both in the category of "small and fast" - they are both substantially faster and smaller than mainstream frameworks like React or Vue, so a marginal performance difference of 5-10% isn't a deciding factor for me.
Gen Hames (whom I believe you know as heyheyhello on github) is working on something called haptic, which might improve on the ergonomics of reactive state management, making it more explicit and transparent vs e.g. S.js and Sinuous. We'll see if this goes anywhere, but I'm hopeful.
Although I try out and use many of these frameworks on private/hobby projects, when it comes to "work work", my go-to choice is and remains Preact. I can explain to a junior how this works, end-to-end, in an hour - and while, in some ways, there is non-obvious complexity inherent in a framework like this that you have to deal with, such as JSX expressions returning VNodes rather than Elements, what the framework does is very easily explainable.
That simplicity, to me, in a work setting, has tremendous value. Understanding the inner workings of it is empowering - I get a sense of confidence when I see someone unlocking something like Preact or Sinuous when I explain it to them. Whereas with frameworks like Vue or Angular, I get the sense that most people don't really understand (beyond the superficial "it makes HTML") how these work, and either aren't very confident, or sometimes overconfident and disinterested in how it works.
The latter isn't necessarily a problem, if the main objective is to churn out code. But from personal experience, I find the confident developer, who works with tools they can understand, and who can pass on that knowledge, is generally happier, more motivated, and contributes to the team experience in perhaps less tangible ways than just churning out code.
Choosing software components, to me, is as much about the human experience as it is about the technical.
I'm not saying any of this to say anything about your framework, by the way - I'm just trying to explain where my personal angle on this might be coming from.
The amount of effort you've put into tutorials and documentation alone makes your project much more complete than most of the open-source efforts in this space, and worthy of real consideration. 🙂
I guess I don't get it. Or I agree with you except I see Solid as the example of what you are getting at.
I never saw Sinuous doing anything different than Solid except shaving some size on the HyperScript version. Maybe I haven't made it clear. But they have identical ergonomics if you so choose to use Solid that way (other than reactive API, but that's swappable).
But I actually find the compiled output from Solid's JSX much clearer what's going on as less is hidden inside the library. The DOM operations are out in the open and resemble the input code. Almost as if you weren't using a templating engine at all.
Solid came about from my experience maintaining and training people on a large production Knockout app over most of a decade. And a lot of the same lessons learned. Balancing abstraction with control.
After reading some of your excellent posts I wanted to try SolidJS but chose Svelte instead partly because your promotion of Marko//Fluurt as well confused me. On initial glance they appeared to be competing frameworks - "Wait, what, which one does he want me to use?" I knew nothing about any of them would need to do some research - " or I can just get started with Svelte "
Congrats on the release of 1.0 - it's given me some impetus to give it a try but I am now comfortable with Svelte. Just a heads up that for newbies like me who just want to get started the decision to chose one framework over another can be as simple as that.
Of course. Marko is incredibly good where it's good (MPAs), but JavaScript server rendering is still a topic that is challenging to explain to newcomers.
This won't be the last time you choose to learn a framework. If you had asked me I probably would have directed you to React or Svelte, pre 1.0. Svelte is a great choice for people new to JavaScript Frameworks. The important part is to keep reading and keep learning.
Thanks! Actually I will start learning SolidJS - I have time.
Are there any component libraries available for SolidJS?
There are a few ones in the works. Active development is being discussed in the Discord if you want to check it out. I expect to see the first few in the coming weeks.
Great work!
Congratulations on this amazing milestone! Amazing to see Solid come through all this way over the years.
Congratulations 🎉👏🎉🎉
Out of topic, does the HMR for solid-element (webcomponent wrapper) works in Vite?
Ahh.. I have no clue. Probably not as written. It was setup for non-ESM HMR like Webpack style. I've found that those differ a bit.
This is great news. I just did a demo yesterday of a SolidJS app I built for internal use at a bank (they don't know it's Solid yet -- they're a React shop). The demo went awesomely, despite having been rushed and the code needed a major refactor. I began that refactor last night.
The new
createStoreis much better than the oldcreateState. That's one of the first things I'm swapping around.I've found a couple of bugs in the docs. I'll report them as soon as I confirm that they're bugs, not just my misunderstanding.
BTW, coming from React and even after having built production Svelte apps more than a year ago (Sapper), I found getting out of the React mindset a lot more difficult than I'd expected. Plenty of frustration around state and signals and when things will re-render. The new documentation is awesome. I snuck back downstairs after my partner went to sleep last night just to get a bit further into the tutorial. Numerous revelations. Thanks!
Looks great, syntax looks very pleasant to work with. I'll have to try it out sometime.
I've been thinking about developing something using JSX or like React, but quicker and lighter and Solid seems to be what I was thinking about. Excited to try it out!
Idea: I was unable to find an
awesomepage like github.com/sindresorhus/awesome for solid. maybe having it below the solid org would be, well, awesome.Awesome to hear. I think the combination of reactivity and JSX makes Solid pretty unique in capability.
Yeah David who handles the community has some ideas here he's been working on the resources section in the website (solidjs.com/resources)
Historically I've been collecting stuff here: github.com/solidjs/solid/blob/main...
But I admit as I've been distracted I haven't been keeping it up to date.
Some comments may only be visible to logged-in visitors. Sign in to view all comments.