knockout
canonic
knockout | canonic | |
---|---|---|
27 | 14 | |
10,412 | 116 | |
0.0% | 2.6% | |
0.0 | 3.8 | |
over 1 year ago | 5 months ago | |
JavaScript | C++ | |
GNU General Public License v3.0 or later | GNU General Public License v3.0 only |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
knockout
- Do You Remember Knockoutjs?
-
A First Look at HTMX and How it Compares to React
The approach is not new, essentially a variation of Knockout, Alpine, and similar "JS-in-HTML" approaches.
-
The Best UI Libraries for Cross-Platform Apps with Tauri
SolidJS and Tauri form another potent combination for creating performant, lightweight, and secure experiences. SolidJS is a reactive UI library that is similar to Svelte in the way it compiles away reactivity and updates the DOM directly, but it also incorporates a fine-grained reactivity system reminiscent of libraries like Marko, Knockout, and MobX.
-
Why are signals still not so popular?
People act like Signals are a new discovery. KnockoutJS was using them 13 years ago and other libraries used them before that.
-
What is KnockoutJS and how is it relevant in Magento 2?
Knockout JS is a Javascript library which uses the MVVM pattern to bind data to certain DOM elements. Within Magento, we usually define a View-Model (which is a .js file) and a Template (which is a .html file), and the data in the template file is bound to the view-model, meaning whenever the data in the view-model changes, the template file changes too.
-
Alpine.js
I still use Knockout[0] for almost an identical experience.
0: https://knockoutjs.com/
-
Concepts behind modern frameworks
One of the first uses of this concept was in knockout, which used the same function with and without arguments for write/read access.
-
Build a Simple App with Xata, Cloudinary, and Knockoutjs
To do this, use a Javascript library called knockout.js
-
"Databinding" in MVC
You could use a JavaScript framework called KnockoutJS which uses the MVVM pattern.
-
Magento alternative: How it compares with Medusa, a JavaScript-based ecommerce platform
Magento is built with PHP. A good understanding of PHP is generally enough to perform different development tasks such as building modules. However, developers often need to work with libraries like Knockout.js and Less when developing themes.
canonic
- Notes on WebAssembly
-
Why aren't devs making desktop apps any more
I just founded a company where we're building a cross-platform native desktop app. Perhaps given we're on HN we can scope this to ask why aren't any _startups_ building native desktop apps?
It's something I wonder about as well. We're building real-time performance critical software, so we don't have much of an alternative. Given these constraints, we also ruled out Electron, Avalonia, React Native early on.
We're using Qt Quick which doesn't get nearly the love it should. I was a web developer for 5 years in a past life, and I'm pretty blown away by how pleasant and well-designed Qt Quick's QML language is. One of our team members created Canonic, https://www.canonic.com to explore how the web might look if QML was used as the document markup for the web.
The popular opinion around Qt Quick is that it is best suited for mobile or embedded projects with a dynamic UI, animations, etc. But over the last few years, it has really become a great desktop solution – to the point where Qt put Widgets into maintenance mode and is focusing efforts on Qt Quick across desktop, mobile and embedded targets.
With Qt 6, the GUI is drawn using native graphics acceleration: Metal on macOS, DirectX11 on Windows, Vulkan on Linux. This makes it really easy to bring in a texture you're drawing in some other piece of code outside of Qt. As a result, the QtMultimedia framework in Qt6 is zero-copy on most platforms with the FFmpeg backend. Frames get decoded if a GPU HW decoder is available, then this texture can be read directly by QtQuick and then rendered by the display server without ever being copied. I don't think there's a single other cross platform framework out there that achieves the same level of usability, performance and easy access to platform native APIs.
Here are just a few non-trivial desktop apps that come to mind using Qt Quick:
- Denon Engine DJ - https://enginedj.com/
- Mark Nottingham: Server-Sent Events, WebSockets, and HTTP
-
I heard you like browsers. So I built a browser that runs in your browser via WASM (for QML instead of HTML)
Here's the website if you want to test it out: https://www.canonic.com
-
A Response to Rich Harris
No, the end goal is to have an entirely separate browser which browses website built with all instead of html / js / css ; since Qt compiles to WASM it's a simple way to try it but the actual thing exists as a standalone desktop app: https://github.com/canonic/canonic
- Canonic Browser: open-source QML Browser
- Canonic Browser – Open-Source QML Web Browser
-
Canonic Browser | Open Source QML Web Browser
GitHub repo: https://github.com/canonic/canonic
What are some alternatives?
Alpine.js - A rugged, minimal framework for composing JavaScript behavior in your markup.
pushpin - A proxy server for adding push to your API, used at the core of Fastly's Fanout service
Vue.js - This is the repo for Vue 2. For Vue 3, go to https://github.com/vuejs/core
braid-spec - Working area for Braid extensions to HTTP
Prism - Prism is a framework for building loosely coupled, maintainable, and testable XAML applications in WPF, Xamarin Forms, and Uno / Win UI Applications..
zotonic_mod_teleview - Mod teleview provides live updating server rendered views.
rivets - Lightweight and powerful data binding.
zotonic_mod_doom_fire
Svelte - Cybernetically enhanced web apps
KittehPlayer - A video player based on Qt, QML and libmpv with themes for many online video players.
Aurelia 1 - The Aurelia 1 framework entry point, bringing together all the required sub-modules of Aurelia.
unpoly - Progressive enhancement for HTML