The Future of HTMX

  Рет қаралды 72,898

Theo - t3․gg

Theo - t3․gg

Күн бұрын

Пікірлер: 357
@2funk2bpunk
@2funk2bpunk 14 күн бұрын
Wait.. html was designed for printers? Seriously? There is no mention of printers on the wikipedia page, and printing html files is always a pain in the butt.
@l10nbit
@l10nbit 14 күн бұрын
It wasnt designed for printers. I was there. It was designed from a paradigm that was based on printed media, but only because we were still all thinking that way.
@tkemaladze
@tkemaladze 14 күн бұрын
it was a joke... relax
@2funk2bpunk
@2funk2bpunk 14 күн бұрын
@@l10nbit ah okay i think i understand now. thanks!
@N1rOx
@N1rOx 13 күн бұрын
@@l10nbit wait, so you're a printer?
@hentype
@hentype 13 күн бұрын
No, but html was designed to look like physical documents. You know, like printed documents on papers but sent and viewed on your computer screen instead. That's why the basic tags you first learn are the basic template with a and then basic text formats like and .
@nitsanbh
@nitsanbh 13 күн бұрын
0:10 WebAssembly is bad? Sometimes Theo thinks the world ends at the horizon of frontend dev. Yeah, the rust project aiming to render UI on a canvas was a failure. But what about running FFMPEG in client side? Or any custom string/image manipulation C++ libs, that already exist, and are able to run 50x times faster than crappy js impl in a web worker?
@vinialves12362
@vinialves12362 13 күн бұрын
Ah finally! I was looking for someone raging in the comments.
@MamoonSyed
@MamoonSyed 13 күн бұрын
WebAssembly’s problem is that most people are making crud apps that have no benefits from being cross-compiled, and fundamentally most people have no idea how to write that kind of code. Theo is a front-end guy so it would very seldom make sense for him to use WA, but there are plenty of use cases for it that are actually compelling. We’re just talking about it in the wrong spheres, in my opinion.
@_sjoe
@_sjoe 13 күн бұрын
I was blindsided by this take, considering many of his sponsors have successfully used WebAssembly. You can find engineering blogs about it from SingleStore, Turso, Prisma, and more. WebAssembly is revolutionary and has enabled amazing things on (and off) the modern web...I really don't understand where he's coming from here.
@_albertlol
@_albertlol 13 күн бұрын
Yeah, what did you expect from the ultimate JS fanboy? If it's not React adjacent, it might as well not exist in his universe. WebAssembly could revolutionize the entire in-browser experience, and he’d still ask if it works with his latest JavaScript framework of the week.
@moho472
@moho472 13 күн бұрын
​@@MamoonSyedYou said it the best. I'm a firmware dev, and I don't know much about Web Development like JS, TS, React, etc. However, Webassembly has me interested in learning it, because I have the prerequisites. Different strokes for different folks.
@flamakespark
@flamakespark 13 күн бұрын
Kudos to HTMX devs for reviving HATEOAS
@ericjbowman1708
@ericjbowman1708 13 күн бұрын
If by that you mean by H, the "H Text Markup Language" then I guess so, because the whole thing's missing the yper. Scripted buttons may meet the definition of hypermedia, but when substituted for links they fail to apply the identification of resources constraint, and fail to behave as links in any way let alone which can be overridden by the user agent based on preference (do I want all links underlined). Hypertext links are what made the Web scale World Wide, not scripted buttons.
@tikabass
@tikabass 11 күн бұрын
I have to assume that's a sarcastic comment.
@ericjbowman1708
@ericjbowman1708 11 күн бұрын
@ Not at all. Do assistive technologies work with your output? That's a non-starter for me, and evidence of architectural mismatch.
@tikabass
@tikabass 11 күн бұрын
@ericjbowman1708 Oh. Not _your_ comment. I surely meant the original comment by @flamakespark.
@ericjbowman1708
@ericjbowman1708 11 күн бұрын
@@tikabass my bad
@ET_AYY_LMAO
@ET_AYY_LMAO 14 күн бұрын
10:00 JSON wasnt really invented as such but was always a language feature in JS, the object notation scheme. Prior to JSON parsers people would use eval() to parse JSON. Its not that you couldnt do dynamic stuff prior to ajax, it was just a hack, you would add script tags to the DOM and then you would load a new script, this technique was called JSONP later, but it was used for a decade before that name. Honestly I think that "react made it easier" is a very controversial take, frontend has become super complex and abstract compared to using just JS and HTML. Sometimes its for the better, but honestly most react projects I have seen have been unmaintainable junk, almost worse than jquery in terms of readability. I think modern webdev adds too much complexity, every static website these days is some kind of react+next.js monster SPA that loads like 100x more code than it loads actual content for the end user, to be frank, react+next.js has turned the internet into ASS, all the SPAs make competitors to google and bing a pipe dream because of the cost and complexity involved in indexing these "apps" that should just have been like 5 html files.
@ericjbowman1708
@ericjbowman1708 13 күн бұрын
Hear, hear. As a RESTafarian since the 90's, I'm getting a huge kick out of the new trend towards "server rendering" because that's exactly what we were saying all along. Lists of identical blank buttons suck. Don't hit me with "it's code-on-demand", an optional constraint, when you don't know how to properly identify resources -- a core constraint, easily met with a LINK not a scripted button! This paradigm shift nerfed accessibility to users of assistive technologies. Please stop!
@ericjbowman1708
@ericjbowman1708 13 күн бұрын
45:00 In XForms, bind a control to and no scripting required for this example. Make the new content permanent by submitting the form. Leave it to the XForms engine to make a PATCH request to update one element, or in the case of multiple edits, PUT the entire form. Twenty years later, it's still a control bound to an element in an HTML document... a self-describing interface, with self-descriptive HTTP messaging. If I want it to look different, I edit the CSS. The js used to implement spellcheck may be a bit different or call a different library, maybe not, but the results are long-term-stable and maintainable.
@MadsterV
@MadsterV 13 күн бұрын
@@ericjbowman1708 Backenders want to do everything in the backend (render plain html, make everything a request). Frontenders want to do everything in the frontend (server components, node) Neither takes full advantage of both sides.
@PraiseYeezus
@PraiseYeezus 13 күн бұрын
"Honestly I think that "react made it easier" is a very controversial take" did you genuinely watch the video...? He said it's easier for large complex projects but adds too much complexity for anything less than that
@ET_AYY_LMAO
@ET_AYY_LMAO 13 күн бұрын
@@PraiseYeezus No, rewatch the video, either you are referring to a different part than me (he makes the statement multiple times). He says it shouldnt be a controversial take, but honestly it is.
@otnima
@otnima 14 күн бұрын
I've been creating websites for 15 years, with modern with technologies I lose so much time fighting with the tools rather working on implementation. It has it use cases but for a simple website I feel it's overkill. The day we have native html/js components with slots, scoped css and reactivity that aren't a complete nightmare is going to a glorious day
@nelakendra2296
@nelakendra2296 13 күн бұрын
What part of that are we missing? I already feel like the native HTML web components do all of that and more cleanly than many of the frameworks. I've honestly been simplifying my code bases and just going native HTML/JS. It's faster, cleaner, it's very easy to understand the code and what's happening, and of course no massive mess of dependencies.
@MadsterV
@MadsterV 13 күн бұрын
the heavy lifting React does today is coordinating the updates to the tree for performance and enabling modularity. You'll always be building tools on top of tools. That's just how IT works.
@otnima
@otnima 11 күн бұрын
@ It's admittedly been a while since I've given web components a go but last tried they were a real pain to create vs the simplicity of the syntax of something like svelte and had aweful compatibility, maybe I should give them another try.
@otnima
@otnima 11 күн бұрын
@ Sure it's always been a case to some degree, but there's a huge difference in complexity in adding a jquery script to your head and you're done vs installing node + npm/nvm/pnpm/bun + installing and maintaining package versions and getting everything to play nice together.
@nickmurdaugh9856
@nickmurdaugh9856 10 күн бұрын
You just described Vue there at the end..
@gradycdenton
@gradycdenton 11 күн бұрын
I've been using what I call the "GOTHAM" stack - Go, Templ (templating, works great at composing fragments), Tailwind, HTMX, AlpineJS (js in HTML), and Air & Make for Dx (hot reloading and trigger Templ codegen).
@robbercarpenter5800
@robbercarpenter5800 13 күн бұрын
Again click bait 😩
@ty.davis3
@ty.davis3 12 күн бұрын
It's so frustrating. I looked up the article before watching the video and couldn't find it because it's not even called what it looks like from the thumbnail. The article talks about how HTMX will live on for years, but the thumbnail makes it look like the developers just abandoned the project
@Tekay37
@Tekay37 14 күн бұрын
14:40 I don't think it's a straight line for all aspects. There are certainly some aspects (like application performance) that have come down. For example, people don't expect websites or programs to fully load within 1 second or less any more. In some cases we fully accept when it takes ridiculously slow 5-10 seconds for an app or website to get in a state where you can start interacting with it. Programs and websites have become so slow (on average) that many people don't realize how extremely fast their computers actually are because non of that speed is actually used.
@colin7452
@colin7452 13 күн бұрын
I think it’s also probably due to the fact that most devs build their apps/websites at home/office on a super fast internet fiber connection with a powerful computer, whereas a lot of users end up using it either on the go on crappy 4G or 3G, on traditional, slow, countryside wifi, and/or on a low-end device. When we build and test the app, we see nothing wrong, because the huge bundle loads fast, but that’s not the reality for a lot of users. We really should make more use of the connection and CPU throttling features when testing.
@Tekay37
@Tekay37 13 күн бұрын
@colin7452 Yeah, websites are tested mostly on the PC you program on, so you don't experience those loading times while developing. Also, examples are often low and some stuff may even be mocked or disabled during development (e.g. ads). But there's also the widespread sentiment that performance isn't important as long as you develop your features quickly (time to market something something).
@GarethDavidson
@GarethDavidson 13 күн бұрын
@colin7452 It's mostly in the request count and cumulative latency. And the being fucking shit of course, which can't be excused.
@nathanbourquin6554
@nathanbourquin6554 8 күн бұрын
I feel like htmx together with a really light weight additional js framework could be really powerful. Make everything fundamentaly really sturdy and backed up by a back end and add some front-end shananigans with the additional js framework. (like animations and such). 99% of websites could work really well that way
@fandorm
@fandorm 14 күн бұрын
You are to young apparently… we did ”ajax” style stuff before ajax. Either use s or script tags did the trick. It wasn’t good looking and it hurt as h..l but it did work. I was doing this end of nineties and beginning of 2000
@leonkernan
@leonkernan 14 күн бұрын
Was going to say, frames or s was the common answer. 1px images also got a bit of a workout.
@ET_AYY_LMAO
@ET_AYY_LMAO 14 күн бұрын
Yeah! We also used JSON long before it was called JSON using eval() to parse object notation...
@hentype
@hentype 13 күн бұрын
yep, the eval hell was real and painful 😂
@gearboxworks
@gearboxworks 13 күн бұрын
Theo is a millennial, what da ya expect? But seriously, bringing up frames is really just pendency for the topic of this video. 🤷‍♂️
@MadsterV
@MadsterV 13 күн бұрын
The point is that this is not how software evolves, and it's relevant because the topic is HTMs' stance on precisely that point.
@DerAlbert
@DerAlbert 13 күн бұрын
Outlook Web Access, together with XmlHttpRequest was in Year 2000, by Microsoft. Gmail was 2004
@gearboxworks
@gearboxworks 13 күн бұрын
Yeah, but Outlook Web Access sucked. 🤷‍♂️
@DerAlbert
@DerAlbert 13 күн бұрын
@ did not say it was good ;)
@michaelmcglynn968
@michaelmcglynn968 10 күн бұрын
Yeah it's pretty outrageous to say Gmail was the first AJAX app when OWA was literally what resulted in XHR in the browser.
@kizigamer6895
@kizigamer6895 14 күн бұрын
Does Astro also not solve this comments thing you were saying Astro can help with that complexity
@threehymns
@threehymns 13 күн бұрын
I love Astro, but he did mention "introducing a build system" as something that could be avoided with tools jQuery. Personally, I Astro is easily simple enough even with a build system.
@actionscripted
@actionscripted 13 күн бұрын
A big component of raising user expectations as the web evolved was Flash. Interactive graphs, games and dynamic, load-free pages and interactivity along with (sometimes absurd) animation. It could be built with visual tools and could scale up to video streaming, 3D and even standalone apps. It wasn’t accessible and crawlable (well…not fully) and it was absolutely the right thing to leave it in the dust once standard web APIs caught up. But this was how we did things for a long time and it was absolutely a contributing factor to user expectations back when websites were at best framesets with GIFs.
@theyreMineralsMarie
@theyreMineralsMarie 13 күн бұрын
But damn was it fun learning and building websites with Actionscript.
@peet._.
@peet._. 13 күн бұрын
Feel like this is completely forgotten - especially when I hear things like "before AJAX building a complex web app was basically impossible" ... I mean I've been building single page apps since like 2003, and I'm by no means amongst the first to do so. Flash WAS a ubiquitous web technology - very few people did not have flash installed back then because a lot of big websites used it to make experiences that absolutely were not possible to match even going into the mid-2010's. It was flash that drove user expectations of the web and the creative's that it attracted with its toolset - shame that it was essentially murdered by Adobe, who would rather see the technology die than act toward some kind of open standard based around flash.
@nikomancer69
@nikomancer69 13 күн бұрын
@@peet._. Theo forgot about Flash which is a very un-millennial thing of him to do. That shit was our childhood, man. Also, Java Applets were a thing too, unfortunately!
@theyreMineralsMarie
@theyreMineralsMarie 8 күн бұрын
@@nikomancer69 learning ActionScript felt like learning magic.
@SebastianBenderSkeptic
@SebastianBenderSkeptic 14 күн бұрын
I remember when jQuery was a godsend, it saved us from having to deal with all the inconsistent browser implementations. I still use it today. I just dont like how painful it is to debug through all the wrapper functions
@mcspud
@mcspud 11 күн бұрын
$.ready() baby
@AndrejFidel
@AndrejFidel 14 күн бұрын
Btw, if you want to drop in a script tag and get superpowers, you can use Vue 😉
@ET_AYY_LMAO
@ET_AYY_LMAO 13 күн бұрын
imo vue is flawed in other ways than react, but it still ends up putting the webstack on its head, reinventing the wheel. nuxt.js devs think they are hot shit because they finally figured out how to render HTML on the server side ... -ish which then requires a complete rehydration to have any kind of functionality. I wonder how many gigawatt hours of energy is wasted by modern webdevelopment paradigmes every year.
@gearboxworks
@gearboxworks 13 күн бұрын
And all the complexity that comes with it...
@mattmmilli8287
@mattmmilli8287 11 күн бұрын
Vue stinks. At least with React you are learning pure JS. Not weird Vue only attributes to put on tags and stuff
@Darrian.
@Darrian. 8 күн бұрын
@@mattmmilli8287 React is “pure JS” and doesn’t have React-specific attributes to put on tags? 😂
@guuliggr5421
@guuliggr5421 Күн бұрын
Someone has skill issues.
@hbobenicio
@hbobenicio 13 күн бұрын
As a java dev, I feel that hmtx is just reinventing jsf, which was the way to go until angular/react/spa revolution happened. We've learned from this transition that jsf was really bad because it's stateful to the point it hurts scalability. How hmtx differs from this issue? Does it makes our backends just render html and control front events or is it a full package of stateful problems? Can we continue to stay stateless when using htmx?
@nightshade427
@nightshade427 13 күн бұрын
you can use htmx and alpinejs (alpinejs is based on vue but takes vue and merges it into the hypermedia itself) or alpinejs and alpineajax (instead of htmx), and go even further to matching client side expectations while still usimg hypermedia based approach
@Frexuz
@Frexuz 11 күн бұрын
alpine doesnt work if you turn on CSP, we had to move ALL binds from the view to separate js files. even their "CSP-mode" only supports very few things. ZERO expressions (like !-not)
@nightshade427
@nightshade427 10 күн бұрын
htmx has similar csp issues, both are augmenting html to do things that aren't currently supported, hopefully similar ideas will make it to html proper, in the meantime if you want really strong security, it's probably best to use vanilla js and stay as small as possible with little to no dependencies
@Frexuz
@Frexuz 10 күн бұрын
@@nightshade427 we didn't have any issues related to htmx tbh. Only alpine. 🤷‍♂️😊
@sohomdatta
@sohomdatta 14 күн бұрын
4:15 Theo, you are underestimating how popular jQuery is, literally Wikipedia and Amazon use it as of today
@comradepeter87
@comradepeter87 14 күн бұрын
pretty sure even this KZbin page uses it somewhere (since I can totally do `$('video').playbackSpeed = 2;` from the console).
@coolemur
@coolemur 14 күн бұрын
Websites HAS jQuery (as legacy). But any developers with common sense don't USE it. If I would see developer using jQuery in 2025 I would instantly assume that developer has low competence in web development and can't keep up with technologies.
@raineaeternal
@raineaeternal 13 күн бұрын
@@coolemur Either they don't keep up, or they just want to make apps that *work.* A lot of web apps today have random intermittent issues because they have so much complexity, which them leads to unstability. It's not entirely unheard of to just make something available and have it just *work.*
@very_unique_username
@very_unique_username 13 күн бұрын
@@comradepeter87Chrome DevTools support $ as a shorthand for document.querySelector(), it’s not jQuery though
@hentype
@hentype 13 күн бұрын
@@raineaeternal Yep, I started with jquery and would rather use that for a blog that only needed a basic comment section instead of using a whole framework for a couple basic function. JQuery doesn't scale well but in cases where there isn't any scaling needed and you already know how to write the needed script from scratch in a minute it just works best. When making more feature rich and modern projects I'd opt to the ones I already know like react or vue but I'm lucky to have these legacy standards in my skillset as well.
@DownUpward
@DownUpward 12 күн бұрын
I love to see htmx getting recognition as a viable, low-complexity alternative to React for many use cases!
@samuelpucat3151
@samuelpucat3151 13 күн бұрын
37:10 You can create polygons in excalidraw by connecting line's starting point with ending point and setting background on it.
@nextentrepreneur9288
@nextentrepreneur9288 13 күн бұрын
"the markup language for printers" that's not true, HTML was designed primarily for the web, to display and structure content on web pages.
@aceman0000099
@aceman0000099 12 күн бұрын
I think it was a joke
@akaia_shadowfox
@akaia_shadowfox 13 күн бұрын
WASM === bad? Did I just completely miss the point or you're serious about it?
@_sjoe
@_sjoe 13 күн бұрын
He truly has no idea what he's talking about in this video. Some of his videos are better than others, but this one was a disaster. Not even 10 seconds into the video, he has completely fabricated something (HTML created for printers???) and made a terrible take about something he obviously doesn't understand (WebAssembly). Even many of sponsors (SingleStore, Turso, Prisma, etc.) use WebAssembly...
@gearboxworks
@gearboxworks 13 күн бұрын
@@_sjoe- He is not completely wrong about HTML *originally* being created for printers, if not just a little off base. HTML was originally an application of a much more complex markup language. Any chance you know what that language was? As for WebAssembly, it is a great technology. But it is not a panacea, nor it is a technology that has gained widespread adoption after 8 years in the market. 8 years at web pace is plenty of time for it to have caught fire if it was going to - and there is no guarantee it ever will. IOW, it is a great niche technology, but it is best for a niche. That said, having been doing web dev since 1995, and having built a Chrome plugin using HTMX with a Go backend, I think Theo is mostly spot-on in this video.
@nikomancer69
@nikomancer69 13 күн бұрын
Not sure if you were doing frontend in 2018, but there was a weird moment in Front End land where Web Assembly had a moment in the sun. IT was the hot promising technology. It was unironically billed as the javascript killer. People wrote breathless blogposts about how the fall of Javascript was imminent and how we would be moving towards a beautiful future where we wrote our crud apps in Rust (As everything should be written in Rust). WASM is awesome and opened up a number of valuable use cases on the web. A number of great companies use it prominently in their stack. But if you are comparing it to the community hype, it delivered on none of the things people were really excited about.
@Malix_Labs
@Malix_Labs 14 күн бұрын
I am very happy with the trending up release of multiple high quality and long videos of yours recently
@normanlorrain
@normanlorrain 13 күн бұрын
The term I like for this is "dynamic range ". I really like technologies that scale down as well as scale up. Right tool for the job.
@milesfranklin9864
@milesfranklin9864 9 күн бұрын
Thanks a ton for putting this together. Really appreciate it.
@marty0678
@marty0678 11 күн бұрын
Before HTMX you could return partial templates no problem and swap out sections of the app easily with Django. That's how things work (and still do work) before HTMX. HTMX just makes it easier with less boilerplate.
@deatho0ne587
@deatho0ne587 12 күн бұрын
Love what you are saying about jQuery, yes it is on 75% but what of those are still being maintained, used, and being used by how many users. HTMX is great for what it needs and FrontEnd Frameworks (react, angular, ...)
@jwr6796
@jwr6796 13 күн бұрын
I, too, love the idea that I could just leave my car in the driveway for years and all the rust it accumulates will make it drive better.
@gearboxworks
@gearboxworks 13 күн бұрын
No pun intended? 🤔
@nightshade427
@nightshade427 13 күн бұрын
your rails example is outdated, rails has hotwire (htmx like behavior), and turboframes (template fragments for streaming via hotwire)
@tomhpolo
@tomhpolo 9 күн бұрын
not only outdated, but also wrong with respect to what built-in to rails like 15 years ago. rails had partial template fragments with "rjs", on the same timeframe as intercooler.js. If you jump in now, it's very easy to think "oh, everyone was making jquery spaghetti, then intercooler came out (which was great, but not adopted at eco-system-shifting levels), then htmx (which is theo is excited above) and now people are shifting in this direction.". rails had things built-in to the framework which were on the exact same path and timeline as htmx (rjs, pjax, jquery_ujs, hotwire). Carson and DHH having both been pushing for the same types of pragmatic primarily-serverside/non-spa architectures/libraries/frameworks the entire time
@EightNineOne
@EightNineOne 2 күн бұрын
Yeah and Hotwire is even more comprehensive than HTMX
@avneet12284
@avneet12284 11 күн бұрын
Hey Theo, you mentioned a video in which you talk about the BE complexity of UploadThing. Any idea which one it is?
@jimratliff
@jimratliff 13 күн бұрын
The most-brilliant Theo I’ve seen. This perspective on a historical review of web development is insightful well beyond HTMX (as someone reading the title of the video might be expecting).
@allyourfuturebelongstochina
@allyourfuturebelongstochina 13 күн бұрын
It’s full of misinformation. It sucks because he’s teaching people a false history.
@designgears
@designgears 13 күн бұрын
I suspect HTMX is what inspired Livewire, don't know how I have lived without it!
@SamanthaKerr-c6u
@SamanthaKerr-c6u 9 күн бұрын
HTMX is great and I take my hat off to Carson Gross - but standardising it into the browser (as in Triptych Project) is so necessary. It's good they're starting small - hopefully the browsers will adopt and run with it. Bravo Carson, and thanks Theo for a great video.
@pmiddlet72
@pmiddlet72 4 күн бұрын
I'm not a front end dev, but I keep front end stack (or possible front end components) in mind within the app engineering process from the back end. Ok that sounds very Prime meme'ish. Anyway. The moral is that complexity in JSON went WAY up. And writing APIs to allow application admins working for our clients to access data became a real problem. The first hint that problems were on the rise from the clients' perspective was developing APIs using JSON of non-fixed depth (NFD). This meant that, for any API call that pulls data in JSON format, keys MAY or MAY NOT be present in the output depending on whether or not they were used for a particular dataset and whether or not they contained data (even if those keys were expected). I personally found this to be a bit nightmarish as this meant to extract data from an API, I would have to create a gazillion checks to see if keys even existed, especially in cases of crappy API documentation. In some cases and on some platforms, ALL keys were on the table for this type of behavior (except some of the 'header' keys that are often static). What this meant for statisticians, DSs and MLEs was (and still is) having to write FAR FAR more code to get reliable, reproducible, and valid data from those APIs. This isn't a good user experience either. I know that the rule with APIs is to be 'stingy' with data access. One really must be this way for the obvious reasons, but holy shit can this become a tangled web. What I fail to see is whether or not writing an API with an NFD JSON file is any more secure than fixed depth JSON where all keys are presented, and if they're empty, the return is simply an empty set (list, dict, whatever).
@jonikyronlahti
@jonikyronlahti 12 күн бұрын
Something I really appreciate in a tech stack and something that is not often talked about is: future proofing. At first a project might seem simple and you might think that (e.g.) HTMX is "good enough", but this has bitten me in the ass SO MANY times... All it requires is one little feature that requires a lot of control in the client (e.g. very complex form) and you wish you had futureproofed a little. It is so awkward to tell your client that the project you have been building the last year needs to be rebuild with some different technology if they want some specific feature(s). The price of dev environment/build complexity is well worth it when I know that whatever the client asks, I can build it.
@nikjs
@nikjs 12 күн бұрын
i need htmx to automatcally pickup a value from localstorage (the token) and include it in a header in every api call made by htmx on the page. I don't want to have to add excessive amounts of boilerplate in my htmx tags for the same. Any solution? Once we're logged in, we typically need to use the same token for everything moving forward. It should be straightforward to just declare that stuff somewhere up in .
@Latent33
@Latent33 12 күн бұрын
With htmx you should ideally be using cookies as they are far more natural for returning your jwt or other auth token and much more secure than localstorage
@mihirphadnis2
@mihirphadnis2 14 күн бұрын
comically HTMX toppled React in JavaScript Rising starts for #1 spot on Frontend Frameworks. Does that mean It has received wider adoption? Probably not...
@nikomancer69
@nikomancer69 13 күн бұрын
There are two kinds of languages, ones people love and ones people use.
@EightNineOne
@EightNineOne 2 күн бұрын
@@nikomancer69 100%. That’s why Java is still huge.
@theacademe
@theacademe 5 күн бұрын
HTMX feels like a successor to Beebole PURE, from 15 years ago... updated for a newer tech stack. We used PURE to enable the same functions, just not as simply.
@skeleton_craftGaming
@skeleton_craftGaming 14 күн бұрын
Good SQL is fast the issue is that MySQL isn't a good... I do think that htmx could be the next jQuery [if anything can] Im pretty satisfied with raw dogging jQuery
@defidelity
@defidelity 12 күн бұрын
Give htmx a trial, you wouldn't need to raw dog json no more
@michaelweaver4439
@michaelweaver4439 13 күн бұрын
What the hell are you smoking!? HTML was not created for printers - and if that was an attempt at sarcasm - please don’t - you obviously don’t understand sarcasm.
@gearboxworks
@gearboxworks 13 күн бұрын
Then what was HTML first created for? And before you respond, note that HTML was originally designed as an application of a much more complex markup language used for complex document formatting where semantic information needed to be embedded. Maybe you know what the complex market language was called and what its use-cases were? BTW, if you do not know I am sure ChatGPT will be able to tell you, if you are motivated enough to ask it. And no, the markup language was not designed for printers. But it is not a stretch to say it was, and besides, I doubt a millennial like Theo would know the specifics anyway.
@nikomancer69
@nikomancer69 13 күн бұрын
HTML uses print media as its main metaphor (Page of HTML, Web Page, Document Object, etc.). In some cases this is very helpful when the websites you're building are roughly similar to a book or magazine page. For web applications that have lots of interactivity, the metaphor becomes strained. No idea if this is what Theo meant, but I do think it is right to say that it was essentially designed for printers since it was following the printed page paradigm.
@allyourfuturebelongstochina
@allyourfuturebelongstochina 13 күн бұрын
@@nikomancer69no. Tim designed it to share documents to be viewed on a screen.
@Junky1425
@Junky1425 12 күн бұрын
I'm a robotics/AR guy who works mostly there and writes applications for that to move, etc. So I'm a backend guy and i love my backend. I had also a talk with a bit more frontend guy and he said hey use react you can do everything with that, which i need for a web application which I write in my freetime. But as a C#/C/C++ guy i hate JS overall. So I went with the stack: Django (Python) for the backend, with db. And HTML, TailwindCSS, HTMX for the frontend. Yes i have also some vanilla JS in my webpage to do some dynamic stuff but that is chatgpt generated simple code like hide elements with classes and show them again. or create html and insert it to a specific place. For me personally that is more then enough frontend :D And I don't want to dig into Angular/React/Vue and all of that, to make some dynamic things like a search or comment (I do that without HTMX :D and reload the page completely). But currently i was able to do everything which i want to do with HTMX and VanillaJS. So perfect stack for me :D
@ReadJohn1421
@ReadJohn1421 10 күн бұрын
As a father shows compassion to his children, so the Lord shows compassion to those who fear him.
@xpamamadeus
@xpamamadeus 13 күн бұрын
its really impressive how we write framgents in jsp 15 years ago with jquery and ajax same way,and now its in again
@bartech101
@bartech101 13 күн бұрын
Theo: "People think I don't like HTMX but I simply think HMTX sucks"
@abeldropdout
@abeldropdout 13 күн бұрын
Can you please be adding the blog links in the description ?
@mirata9
@mirata9 12 күн бұрын
I get it Theo, you need a thumbnail to promote engagement. But do you always need to look like you’ve just been told your family was murdered
@redfernguitar
@redfernguitar 11 күн бұрын
That's a fair analysis, like I'm working on a browser based DAW so I am not looking at htmx. I'm looking at preact because I want it to be small and fast but be conceptually compatable with react.
@MarkAnkcorn
@MarkAnkcorn 11 күн бұрын
What's the app that Theo uses to draw these boxes and such? I keep trying to pause and get a glimpse of the menu bar or app switcher, but can't seem to figure it out
@kp8752
@kp8752 4 күн бұрын
Excalidraw
@TheHronar
@TheHronar 13 күн бұрын
You can maintain the behaviors of the previous defaults while iterating on new defaults. Users can continue to use your application'/library/whatever in the way they know how or they can learn the (hopefully) improved way of doing things.
@TheHronar
@TheHronar 13 күн бұрын
And if you don't want to maintain that backwards compatibility forever, that's what deprecation is for.
@TheHronar
@TheHronar 13 күн бұрын
A period of those behaviors co-existing before users are forced to adopt a new way is pretty standard and I think works well.
@mohammedmaqbol9397
@mohammedmaqbol9397 10 күн бұрын
is that markojs in 0:09 ?
@MadsterV
@MadsterV 13 күн бұрын
So with HTMx if I find a layout bug and I need to move some divs around, I have to update the backend? yikes, no go.
@ankitsanghi
@ankitsanghi 13 күн бұрын
Not really. You’d just move the divs around in the HTML file you’re changing. No need to update the backend
@defidelity
@defidelity 12 күн бұрын
HTMX doesn't determine anything in your backend, it only helps you send requests and determine where the response to that request goes.
@MadsterV
@MadsterV 11 күн бұрын
yeah I meant UI changes inside the component. The layout comes rendered from the server, doesn't it?
@gentlemanbirdlake
@gentlemanbirdlake 13 күн бұрын
what if you need to render localized versions of the data? timezone datetime or number formatting with htmx?
@gearboxworks
@gearboxworks 13 күн бұрын
HTMX will handle that brilliantly. It can do anything a backend can do, including marshaling client information from the front-end.
@JLarky
@JLarky 13 күн бұрын
Html for printers? You are thinking about PostScript
@Darbokst
@Darbokst 13 күн бұрын
what would I use with HTMX/HTML to get info from a db like supabase?
@jasonbatchelor4604
@jasonbatchelor4604 12 күн бұрын
How much of that "straight line" increase in user expectations is real, and how much is due to marketing hype? I find there's a definite gap between what users actually want or need vs. what marketing people (whose money is tied directly to getting users to pay for things that may or may not yet exist) are pitching.
@craig.martin
@craig.martin 10 күн бұрын
Personally, I'm loving how FastHTML piggy-backs on HTMX for the simplest, most beautiful solution for python-based web apps.
@khoaphananhtran362
@khoaphananhtran362 10 күн бұрын
what is the tool that he is using for note taking?
@wiretransfer
@wiretransfer 4 күн бұрын
seems to be excalidraw
@owenwexler7214
@owenwexler7214 12 күн бұрын
33:00 prototyping a Go backend for my CRUD app and for the routes I’ve written so far I’ve knocked 20-25ms off response times vs Express. If that translates to prod that’s definitely worth it.
@jj0b
@jj0b 6 күн бұрын
I'm curious why Theo says you shouldn't use Go for a CRUD app. Seems to me like it is ideal for that.
@RogerValor
@RogerValor 9 күн бұрын
Somehow this history lesson completely leaves out Java and Flash Applications, or Silverlight and whatnot plugins, including the era of weird stuff like GWT and YUI. But that would also explain, why the expectations were actually already higher than it was possible to do things, and what webapps had to compete with.
@virtual5754
@virtual5754 13 күн бұрын
Should we use react for static blog? As soon as astro makes proper runtime revalidation - no. Until then - yes, nextjs
@IAMDean
@IAMDean 13 күн бұрын
The best type of Theo video
@4115steve
@4115steve 13 күн бұрын
what would it be like making a zig web app/3d game with htmx, websockets, wasi and wasm?
@antonf.9278
@antonf.9278 13 күн бұрын
Once you load wasm you probably won't have get much use out of htmx. The whole point of htmx is to keep complexity down, while wasm is a powerful but complex tool.
@alekseykostyuk3806
@alekseykostyuk3806 10 күн бұрын
There is a solution, which isn't a Framwork - microfrontends. Using just a bit of react to implement those comments section might be ok if it doesn't require learning all the tooling around. Just do not store that state on the client ) btw, take a look to symfony live components.
@kobibr9362
@kobibr9362 9 күн бұрын
Rust community need to push worker-rs it is awesome. It definitely removed the idea that Wasm is bad from my mind.
@thegrumpydeveloper
@thegrumpydeveloper 13 күн бұрын
Got excited about singlestore but drizzle says we can’t use order by and limit together 😅😢wat? Seems like possible by using count or by adding a sort key but still surprising. Would like to see a more deep dive into single store.
@wiretransfer
@wiretransfer 4 күн бұрын
if anybody else is wondering what app Theo is using to draw, it seems to be excalidraw
@SapioiT
@SapioiT 13 күн бұрын
Why do we not simply get alternatives to HTML and CSS, instead of getting more and more frameworks which mostly solve the same things in different ways? Especially since we're rapidly approaching the level of AR (augmented reality), where people are going to expect 3D websites and apps.
@Ligma_Shlong
@Ligma_Shlong 13 күн бұрын
no one wants 3d websites
@economicist2011
@economicist2011 13 күн бұрын
@@Ligma_Shlong Oh come now, who wouldn't want shopping for a new GPU to be like the final showdown scene from "Hackers" ?
@gearboxworks
@gearboxworks 13 күн бұрын
Well, HTMX is just extension of HTML implementing the "missing parts," with a goal to get HTML to adopt its features so that it can just go away. So, you wish for it and HTMX grants it. 🤷‍♂️
@gearboxworks
@gearboxworks 13 күн бұрын
Well, HTMX is just extension of HTML implementing the "missing parts," with a goal to get HTML to adopt its features so that it can just go away. So, you wish for it and HTMX grants it. 🤷‍♂️
@nikomancer69
@nikomancer69 13 күн бұрын
We don't get alternatives to HTML and CSS because, unfortunately, the expectation for the web browser is that everything is backwards compatible and that dark triad of technology (and also kinda sorta web assembly) are the primitives for the web browser. It's akin to asking why we don't get alternatives to machine code and instead just build interpreters that mostly make it easier in different ways.
@hafizmuhammadahmadfareed
@hafizmuhammadahmadfareed 13 күн бұрын
Please make a full video on SingleStore and how to use it in a real life project. Please please love from Pakistan.
@lxn7404
@lxn7404 11 күн бұрын
Something you didn't mention: as a rule of thumb, vulnerabilities grows proportional to complexity
@leonkernan
@leonkernan 14 күн бұрын
Videos like this remind me how old I am...
@yuryzhuravlev2312
@yuryzhuravlev2312 12 күн бұрын
HTMX it's illusion, yes it's only a small extra complexity on frontend BUT now you should do all this routing, complex hierarchy of templates on backend. If you need render only part of this template it's not trivial or manage it's properly.
@RogerValor
@RogerValor 9 күн бұрын
why would webassembly be bad? i mean the app / server idea about it is, but web assembly itself is pretty dope
@succatash
@succatash 13 күн бұрын
Isn't singletore founded by the neondb guy
@KriLL325783
@KriLL325783 13 күн бұрын
Anyone knows what app he's using for that blackboard at 11min?
@gearboxworks
@gearboxworks 13 күн бұрын
Excalidraw
@nikomancer69
@nikomancer69 13 күн бұрын
Excalidraw with dark mode turned on. Give it a shot, it's neat.
@4115steve
@4115steve 13 күн бұрын
I thought the HTMX sucks video was sarcasm, but I didn't know how to decipher some of technicalities, and your acting was really good. Like I was almost worried that you might be serious LOL
@sobanya_228
@sobanya_228 13 күн бұрын
Some sites might just be importing jQuery like lodash, not necessarily basing their entire rendering on manually using jQuery
@ДмитрийКарпич
@ДмитрийКарпич 9 күн бұрын
So, why not just take an Astro? It's just fit all cases from static pages to dynamic. One tool without funky syntax or "reinvent wheel " ideas.
@JD-yz8cn
@JD-yz8cn 13 күн бұрын
It was possible to do the things you mentioned before AJAX or JSON with script injection. Most people just weren't doing it.
@nikomancer69
@nikomancer69 13 күн бұрын
It's clearly a pretty simplified history of web dev. Not even one mention of Flash or Java Applets in there.
@AbegazNap
@AbegazNap 14 күн бұрын
I don't usually agree with Theo, but he's largely correct with this.
@bihan1429
@bihan1429 12 күн бұрын
Nobody cares if you agree or not
@krumbergify
@krumbergify 14 күн бұрын
Programming languages, frameworks and protocols are just tools. They are only good or bad if you know what you want to achieve, using certain resources in a certain timespan. The human side also plays a huge part. If your team already knows framework X, then X might be the ”best tool for the job” although framework Y might have some technical advantages and would have been the ”best tool” if your team didn’t know either X or Y.
@Malix_Labs
@Malix_Labs 14 күн бұрын
@@krumbergify tools can be objectively criticized. This is why they are still being constantly improved
@krumbergify
@krumbergify 14 күн бұрын
@@Malix_Labs ”Time” and your current software capital are key here. What timespan are we looking at? Let’s say that you have a messy codebase in C and you prefer to have it in Rust. Rewriting it in Rust would take many years and it would most likely yield a better codebase, but you need to deliver features here and now using a team of people who know C much better than Rust.
@chakritlikitkhajorn8730
@chakritlikitkhajorn8730 13 күн бұрын
@@Malix_Labsif you want to criticize anything objectively, you need to have an objective first. And many programmer seems to think their objective is everyone else objective. Like, this language is the most performant (and that is what I passionate about so that’s my objective) therefore, this is the best language. Well, other factor like maintainability matters as well. There are circumstances that performance matters the most but not always. There are times that maintainability matters the most, but not always. Or, I am really productive in this language therefore we all should use this. My teammate struggle? Skill issues. Many programmer seems to criticize every technology without aware that their chosen objective criteria really stem from subjective passion of themselves.
@Malix_Labs
@Malix_Labs 13 күн бұрын
​@@chakritlikitkhajorn8730 > many programmer seems to think their objective is everyone else objective By definition, this is true You are probably mistaking it with subjective
@gearboxworks
@gearboxworks 13 күн бұрын
All too often though a team does not throughly evaluate all relevant criteria before making a choice. Chances are that most teams today will get it wrong it is in important for the website to be maintainable for decades unless the sponsor of the project makes that the primary goal of the project (think Jimmy Wales and Wikipedia.)
@maimee1
@maimee1 14 күн бұрын
Didn't Vue also have petite Vue?
@hentype
@hentype 13 күн бұрын
I remember that brief time when vue and bulma were being promoted. Tailwind eventually won but it was a fascinating era when I started learning more of these js frameworks outside jquery.
@MDavidR
@MDavidR 13 күн бұрын
Hm. But this is the same thing that Rails 8 does. And you've been, I would say, cruel against the Rails approach.
@zeocamo
@zeocamo 13 күн бұрын
the xml was so bad, that it die in 2005 but no one could stop using it as it was on all the sites. we try any things to replace it, but the only thing that work for all the backends was json
@arytiwa4351
@arytiwa4351 13 күн бұрын
I think the Wasm part was a mistake, ig you meant react right ?😅
@baddrivers759
@baddrivers759 11 күн бұрын
AJAX (in the form of XMLHTTP, which later became XMLHttpRequest) was first created and implemented in Microsoft's Outlook Web Access. Yes, Microsoft invented the concept of AJAX. GMail didn't even exist until 2004 (5 years later). If you are going to quote history (in your great videos), at lease get the history correct (a simple Wikipedia search would help, not that I needed to, as I was there using it in 1999).
@ivanmaglica264
@ivanmaglica264 13 күн бұрын
Strange, I used XMR in 2004 to update parts of my app, and I never used XML even back then. We used JSON even back then.
@jeroenvanattenhoven6202
@jeroenvanattenhoven6202 13 күн бұрын
What drawing app is this?
@Shekelvin4
@Shekelvin4 13 күн бұрын
waiting for answer
@nikomancer69
@nikomancer69 13 күн бұрын
Excalidraw.
@ImadEddineTerraf-ep8ky
@ImadEddineTerraf-ep8ky 12 күн бұрын
Can you do a video on React to Next migration?
@sprobertson
@sprobertson 13 күн бұрын
Once it gets into the template fragment stuff I'd rather just use React which feels a lot more procedural and less magic
@Vladhin
@Vladhin 11 күн бұрын
I disagree on users expectations part. I would say many many users expect to get information from the internet and expect those informations to be accessible - that's it. Single page app? Why? Most used websites in 2024 were google search, youtube, facebook, instagram, whatsapp, x, wikipedia, chatgpt, reddit, amazon - exept for fb, yt and instagram these are not most complex websites and also they don't have to be that complex. Users are not demanding it, the companies do raise the bar for themselves to attract more and more users but it's not an expectation, it's business. Thin users pool is expecting much like professional creators but the rest of us could deal with refreshing - no problem.
@nm6x
@nm6x 12 күн бұрын
My I don’t want to put effort but I want to do pretty things stack currently is: Pico CSS, AlpineJS and HTMX.
@jurgenkranenburg1309
@jurgenkranenburg1309 13 күн бұрын
jquery is still awesome though when having to write vanilla-ish javascript. I still use it when writing laravel apps without a javascript front end framework
@cim8097
@cim8097 13 күн бұрын
Cringe thumbnail again, nah I'm good.
@robrobob
@robrobob 13 күн бұрын
The video was actually quite good, but I agree with you about the clickbait thumbnail.
@trig1dentity
@trig1dentity Күн бұрын
Hm. Yeah... I agree
@godonholiday
@godonholiday 13 күн бұрын
Not sure about the complexity graph. Apps had gotten or were getting so complex that we needed backbone.js and likes just so we could wrangle the code. So complexity wasn’t low. Less than now sure, but not basic.
@travelinzac
@travelinzac 10 күн бұрын
re: comment section in a page and "react taking over the entire app", nah man, put an empty div in the static page, and render react into just that div. boom comments section in react without taking over the entire app.
@LadyEmilyNyx
@LadyEmilyNyx 13 күн бұрын
I still can't see any niche that this fits into that isn't better served by JS/jQuery. Especially since you still have to write a separate backend.
@javierrodriguez4218
@javierrodriguez4218 13 күн бұрын
13:50 source: trust me bro
@_albertlol
@_albertlol 13 күн бұрын
His whole point doesn't make sense to me. I would bet that at least 80% of websites still haven't bothered to switch to any of the new hyped web technologies and just stayed on LAMP.
@nikomancer69
@nikomancer69 13 күн бұрын
@@_albertlol I'm not sure what your point is. Of course there will be lots of incumbent tech stacks. That's is normal. But what I think he's getting at is like, in the past, if you wanted to do online chat in a browser, you had IRC. IRC was super simple in terms of UI. Now, when I think of chat in a web browser, I think of Discord or Slack. Discord has a whole lot of stateful stuff going on in its UI. The IRC chats are still there. I still even use them from time to time. But the next company that wants to release something they want to be *the* next big chat app will be competing against Discord in terms of user expectations and will need to make meaningful improvements. That's the complexity arms race. But those meaningful improvements will be easier because the technologies that enabled them proliferate further and become standard patterns and abstractions for building apps. Component architecture in JS front end frameworks is a good example of this. For companies or apps not caught in that complexity arms race, there's not really much need to pay attention to all of this stuff.
@williamcleek4922
@williamcleek4922 10 күн бұрын
Add in webasm representational state sync glue and some real time client session debugging via server side then that would be cool.
@agentminecraft9986
@agentminecraft9986 11 күн бұрын
Babe I get to choose the movie tonight
@matthewdolman
@matthewdolman 13 күн бұрын
I think you are really missing the mark on your understanding of how widespread the use of jquery is these days. I build integrations for all major frontend frameworks which include react and jquery and the use of jquery is at least 10x of that of react, and we have major uk customers. I'm not saying it's good, just saying it's a fact of life.
OpenAI is terrified (there's finally a great open source LLM)
34:18
Theo - t3․gg
Рет қаралды 101 М.
From React To HTMX
40:01
ThePrimeTime
Рет қаралды 346 М.
Is HTMX a Joke??
32:15
Syntax
Рет қаралды 25 М.
Why Your Backend Shouldn't Serve Files
19:40
Boot dev
Рет қаралды 81 М.
HTMX - Say “no” to Complexity | Mark Volkmann
27:04
XtremeJS Conference
Рет қаралды 1,8 М.
Bun's FINALLY A Bundler (and much much more)
29:20
Theo - t3․gg
Рет қаралды 39 М.
The £60 Aldi Espresso Machine
19:53
James Hoffmann
Рет қаралды 1,4 МЛН
I Hate Nintendo and I’m Buying a Switch 2 IMMEDIATELY
12:05
Linus Tech Tips
Рет қаралды 4,2 МЛН
Why Everyone Hates Web Components
1:22:39
Theo - t3․gg
Рет қаралды 86 М.
A Brutally Honest Elden Ring Critique
1:12:24
Lextorias
Рет қаралды 794 М.
It's Really Just That Bad
57:49
ThePrimeTime
Рет қаралды 275 М.
Leaving Everything Behind For Elixir
45:10
Theo - t3․gg
Рет қаралды 144 М.