Violentmonkey itself is built for modern browsers, to be precise, for Chrome >= 57 and Firefox >= 57. So if your browser has Violentmonkey, it is likely it also supports many ES6 features natively, for example, async / await, block-scoped variables, etc.
However, there are many more cool features that are not fully supported by browsers, or some features such as TypeScript and ES modules that won’t be supported in userscripts natively.
In this tutorial we are going to create a project to compile ESNext and other modern syntax to browser compliant code.
Prerequisites
- Node >= 18
- NPM >= 8.15.0
Initialization
Create a new directory for your script:
Thanks to npx
, we can generate the new project with a one-line command:
Under the hood, we use Yeoman to create a project with JavaScript toolchain, compiling source code with Babel, and bundling them with Rollup. See the source code at GitHub.
Now we should get a project with the following structure:
Source code files are kept in src
, and will be compiled to dist/index.user.js
.
src/meta.js
contains the metadata of our script, see Metadata Block for more details. Do not add actual code to this file.
src/index.ts
is the entrance of our script, other files in src
can be imported.
Development
Source code will be watched by the compiler and compiled to dist
once changed.
By installing the compiled userscript from dist
, we can test and keep up with the latest code of our userscript. See also How to edit scripts with your favorite editor.
Building
In this way the source code will be compiled exactly once, and saved in dist
.
The version and author of our userscript will be synced with that in package.json
.
Features
We have quite a few lovely features enabled by default:
Of course you don’t have to use all these features. If you don’t like them, you can simply ignore them or opt out by removing the plugins.
To learn more about each feature, check Features in Userscript Generator.