Electron is a widely hated framework on Linux, but what about the alternatives like Neutralinojs?

In their own words: In Electron and NWjs, you have to install Node.js and hundreds of dependency libraries. Embedded Chromium and Node.js make simple apps bloaty — in most scenarios, framework weights more than your app source. Neutralinojs offers a lightweight and portable SDK which is an alternative for Electron and NW.js. Neutralinojs doesn’t bundle Chromium and uses the existing web browser library in the operating system (Eg: gtk-webkit2 on Linux). Neutralinojs implements a secure WebSocket connection for native operations and embeds a static web server to serve the web content. Also, it offers a built-in JavaScript client library for developers.

Do you experience alternatives like Njs to blend more in the desktop layout, install less junk, use less memory, are more compatible with Wayland,…?

  • winnie@lemmy.ml
    link
    fedilink
    English
    arrow-up
    18
    ·
    3 months ago

    I haven’t use any alternatives, and haven’t developed with electron, but I know that there are another alternative – Tauri. It also uses web-view. It’s built in Rust and allows apps to be developed in JS (providing JS api) and in Rust.

    What I can say – JS support won’t be cross-platform, like we have with NodeJS in electron. Special debug per platform might be required.

  • dan@upvote.au
    link
    fedilink
    arrow-up
    12
    ·
    edit-2
    3 months ago

    Have you tried Flutter? https://flutter.dev/

    React Native is good, and isn’t just a web view. It uses native UI widgets so the apps feel truly native. Many Android and iOS apps use it, and Microsoft ported it to Windows and MacOS and use it in some of their apps (notably, the Xbox app, parts of Office, and parts of Windows like the old Mail app in Windows 10, use it). Unfortunately there’s no stable port for Linux :/

    In theory, someone could port React Native to use Gtk, Qt, or WxWidgets, but I haven’t seen any such efforts recently - there’s a few old projects but they’ve all been abandoned.

    • winnie@lemmy.ml
      link
      fedilink
      English
      arrow-up
      1
      ·
      3 months ago

      Have you tried Flutter?

      I didn’t develop on it, but I’ve used recently one app written in it and it was hot pile of garbage.

      It was slow as a slug, and eat lot of CPU. I’ve also checked web eversion and was astonished as it rendered everything into canvas. It’s really poor design choice to render everything by app itself.

      I guess it was just buggy app, but I didn’t try other apps in flutter, so can’t compare.

      But web demo of flutter UI components with list box was also not so fast. But perhaps it’s just web version. Didn’t know any example of good flutter app.

        • leopold@lemmy.kde.social
          link
          fedilink
          English
          arrow-up
          9
          ·
          edit-2
          3 months ago

          True. If their goal is truly to use the “native” solution everywhere, they should use QtWebEngine on Qt desktops. For the most part, the advantage with Tauri isn’t so much that it’s using the “native” web engine, it’s that not every Tauri application has to bundle a full (probably outdated) web engine. On Linux, this is achieved regardless of whether WebKitGTK or QtWebEngine is used. The first Tauri application you install pulls in WebKitGTK if you didn’t already have it installed, then every subsequent application just uses the same one. I’m personally glad it’s using WebKitGTK despite being a Plasma user. The less we rely on Blink and Blink-based web engines, the better. Having to spend 100MB of my 1TB hard drive on WebKitGTK to achieve this isn’t making me lose a whole lot of sleep.

    • winnie@lemmy.ml
      link
      fedilink
      English
      arrow-up
      2
      ·
      3 months ago

      I believe it uses gtk-webview. So on KDE system you would use GTK as a base. But you anyway would have GTK libs in your system.

  • merthyr1831@lemmy.world
    link
    fedilink
    arrow-up
    4
    ·
    edit-2
    3 months ago

    If you need multi platform support in one codebase, Flutter is a good choice. Ubuntu uses it for their new OS installer and GUI package manager.

    Quite easy to get set up on Linux (though the recommended route is using Snaps).

    No waiting ages for a massive node_modules folder to fill up, nor the general pain of using javascript; dart is a really nice language to write in.

    You wont get the smallest binaries with it, but it’s powerful, reliable, and pretty damn performant for a “non native” framework.

  • bizdelnick@lemmy.ml
    link
    fedilink
    arrow-up
    7
    arrow-down
    4
    ·
    3 months ago

    Alternative for what? I never used electron apps and I don’t see any reason for that. If you are a developer, try Qt.

    • moreeni@lemm.ee
      link
      fedilink
      arrow-up
      21
      ·
      3 months ago

      Qt and Electron are different technologies that achieve somewhat different goals

        • jbk@discuss.tchncs.de
          link
          fedilink
          arrow-up
          4
          ·
          3 months ago

          They have like 3 different, official codebases and clients (and so many 3rd party ones) for so many platforms. No other app I know of is like that, not really a great example imo

      • bizdelnick@lemmy.ml
        link
        fedilink
        arrow-up
        6
        arrow-down
        4
        ·
        3 months ago

        Qt and Electron are different technologies

        Yes.

        that achieve somewhat different goals

        No.

        • moreeni@lemm.ee
          link
          fedilink
          arrow-up
          5
          ·
          3 months ago

          You can’t get a website working as a “native” application with Qt, which is exactly what is Electron’s goal.

          • bizdelnick@lemmy.ml
            link
            fedilink
            arrow-up
            5
            arrow-down
            1
            ·
            3 months ago

            There is a browser working natively in any system. I don’t see any point in bundling a web app together with a browser and calling it a “native” app. The only difference is that you have no address bar in that case.

    • winnie@lemmy.ml
      link
      fedilink
      English
      arrow-up
      1
      ·
      3 months ago

      I’ve just tried Qt based matrix client. Compared to Electron based Element.

      It’s nice, snappy, beautiful, and eats WAY less RAM. But it lacks lot of feature. That’s sad.