- A Case for Compile to JavaScript Interface Frameworks
- Original article: AsyncBanana
- Translation from: The Gold Project
- This article is permalink: github.com/xitu/gold-m…
- Translator: No problem
- Proofreader: KimYangOfCat PassionPenguin
An example of compiling a JavaScript interface framework
Today’s Web frameworks like React and Vue are very popular for creating modern Web applications, and there’s a reason for that. These frameworks help turn code snippets into reusable components that are easily updated based on data by using declarative markup.
But almost all of these framework runtimes require heavy-weight libraries, which represent a performance drain. Also, such interface languages are less powerful and more cumbersome due to the limitations of native JS.
Anyway, what’s the solution to this problem that gives you better performance with cleaner code
These frameworks compile languages optimized for declarative user interface design into native JavaScript. Because these are compiled and do not require large runtime libraries, they are smaller.
There are two types of compilation to a JavaScript user interface framework. One is to use JavaScript for actual logic, like Svelte and Solid. Another uses a completely different language, such as Elm and Mint, which are often not just for declarative markup. In this article we will focus primarily on the former framework. Now let’s look at why we use these frameworks.
Solid can be thought of as a runtime framework, but since it is often used to optimize the compilation of code, in this article I think of it as a compilation of the JS framework.
The compiled JavaScript runs faster
Many compiled frameworks, especially newer ones, are smaller and faster than run-time frameworks.
This is because they can do a lot of optimizations before the code runs, turning it into JavaScript for normal DOM operations and avoiding large packages.
For example, React and Vue designs are more commonly used at runtime than the two frameworks that focus on compilation, Svelte and Solid.
- React uses JSX as compiled, but only based on calls
createElement
The basic grammar of sugar.
Based on BundlePhobia, React and Vue are 39.4 KB GZip and 22.9 KB GZip, respectively.
Svelte, by contrast, uses very little outside of native DOM manipulation, so there is almost no basic package size and only a few small functions to help with DOM updates.
Since the compiler accounts for most of the package size but is not included in the resulting Web application, you can’t quantify the size from Bundlephobia, but the startup time benchmark is a reasonable estimate of the size.
In addition, both Solid and Svelte are significantly faster at run time. According to Krausest Framework Benchmarks, Solid, and Svelte are faster in terms of startup time, DOM operating speed, and memory usage.
As you can see, Solid and Svelte perform better than React and Vue in terms of startup time (influenced by script size and compile time) and memory usage for large Dom operations.
Of course, you have to remember that most of the time it’s not that important. But if you’re looking for better performance, using the compilation of UI code to optimize framework performance might be a good way to go.
For example, if you are developing for users on slow 2G or 3G networks, it is helpful to use Svelte to reduce the size.
Also, remember that while optimized compiled frameworks can be faster than unoptimized frameworks, Vanilla JavaScript is almost always faster, but Vanilla JavaScript is more tedious, which brings us to our second point.
The compiled framework is optimized for less code
JavaScript wasn’t originally designed to create declarative tags like React, and because of that, many of React’s features force you to use functions and methods instead of generic variables like useState(), which isn’t bad but it’s not good either.
In addition, most of the functionality needs to be loaded at run time, so there is very little functionality. Svelte has built-in support for reactive variables, which you can declare using the general syntax let variable = value.
In addition, you can make a reactivity statement with just $:. This can be a little confusing, and here are some examples to help you understand.
import {useState} from 'react'
export default function App() {
let [clicks,setClicks] = useState(0)
return (
<div className="App">
<h1>Clicks: {clicks}</h1>
<button onClick={()= >{
setClicks(clicks+1)
}}>Click Me!</button>
</div>
);
}
Copy the code
<script> let clicks = 0 </script> <h1>Clicks: {clicks}</h1> <button on:click={()=> clicks++ }>Click Me! </button>Copy the code
As you can see, the grammatical style is completely different. Svelte has a more native feel and uses 1/3 less code than React.
Anyway, it depends on what kind of grammar you want, but the editors have added more flexibility to the grammar. You might want to think that the time spent compiling and setting up the compiler outweighs the syntactic advantages it brings, which brings us to the last point.
You’re probably already compiling JavaScript
You may only use native JavaScript, but you still need to compile it, even if only to convert ES6 to code supported by older browsers, or to compress the code. Create the React App in the background using Webpack to execute different code. In fact, React JSX, recommended by the Reat team, needs to be compiled into function calls to create actual elements.
Unfortunately, React wasn’t able to take full advantage of it and optimize it, although they recently made some improvements with the new JSX conversion. Vue Cli also uses Webpack in the background. This means that you don’t need to use a compiler, but you probably will anyway, and it’s pretty easy to set up.
conclusion
Using a framework compiled into JavaScript is not always the answer. Some frameworks that don’t compile to JavaScript are faster than those that use a compiler, and using a compiler doesn’t make it a better framework.
Also, a wide range is compiled. Frameworks such as Alpine. Js are designed to run without any build steps at all.
Others, like React, selectively compile small portions of code. Solid uses JSX, which is a bit like React, but it’s further optimized at compile time.
The final level of compilation is that any code can be compiled, such as Svelte. How much you want to compile is your choice, and each option has its own pros and cons.
I hope you have learned something from this article. Thanks for reading.
If you find any errors in the translation or other areas that need improvement, you are welcome to revise and PR the translation in the Gold Translation program, and you can also get corresponding bonus points. The permanent link to this article at the beginning of this article is the MarkDown link to this article on GitHub.
Diggings translation project is a community for translating quality Internet technical articles from diggings English sharing articles. The content covers the fields of Android, iOS, front end, back end, blockchain, products, design, artificial intelligence and so on. For more high-quality translations, please keep paying attention to The Translation Project, official weibo and zhihu column.