Functional Webcomponents (positive-intentions.com)
from xoron@programming.dev to programming@programming.dev on 27 Dec 11:15
https://programming.dev/post/23381812

I’m creating a JavaScript UI framework for my own projects. It’s a learning journey and I’d like to share my progress.

I’ve written some blog posts about my progress so far:

  1. Functional Web Components - positive-intentions.com/…/dim-functional-webcompo…
  2. Functional Todo App - positive-intentions.com/blog/dim-todo-list
  3. Async State Management - positive-intentions.com/…/async-state-management
  4. Bottom-up Browser Storage - positive-intentions.com/blog/bottom-up-storage

Note: The UI framework is far from finished. I want to share progress to see if there are any outstanding issues I’m overlooking.

#programming

threaded - newest

MonkderVierte@lemmy.ml on 27 Dec 14:53 collapse

Ugh, please no. Please don’t paint UI-elements via JS, if you’re not forced to. It makes for a poor experience for most users, not to mention accessibility.

moseschrute@lemmy.ml on 27 Dec 15:06 next collapse

I spent a lot of time early in my career working on some UI component libraries that I ultimately deemed a failure. However, I learned a lot from that. I’ve found that as I’ve settled into a more senior dev role, it’s become harder for me to experiment.

What I’m trying to say is that best case, you come up with something cool, and worst case, you learn from your mistakes and apply what you learned to the next project!

MonkderVierte@lemmy.ml on 27 Dec 15:08 collapse

Yeah, sure. But in case of a framework, people without that experience start using it wrong.

lemmeBe@sh.itjust.works on 27 Dec 16:00 collapse

Yep. You should already know all the available tools at your disposal before embarking on creating something new. Then you’ll also know best practices and if it makes sense creating something new and how to approach it.

xoron@programming.dev on 27 Dec 15:09 next collapse

Thanks for input. I think it could still work without js-painting given that it’s using the customElement.define().

I’m aiming for something that looks and behaves like react, but without the overhead of the react tooling for transpiling.

JakenVeina@lemm.ee on 29 Dec 04:13 collapse

What are you considering as “paint[ing] UI-elements” in this context? I don’t see anything I would describe as “painting” in the code snippets ay those links.