How to edit scripts with your favorite editor?

Since Violentmonkey is a lightweight script manager by design, its editor is simple and offers just a few options. It doesn’t try to replicate a full-featured editor or IDE, which is problematic anyway due to browser’s hardcoded hotkeys and other restrictions.

Screenshot of the built-in editor and its options

Customization in the extension’s settings:


Excellent external editors exist and using one to edit scripts in Violentmonkey is relatively simple, no need to reinvent the wheel.

1. One-time preparation

  1. Copy the code of the script from Violentmonkey into your editor.
  2. Save it to a file and give it a name ending with .user.js

2. Open this file in Violentmonkey installer

⚠ The local file’s name must end with .user.js, otherwise it won’t be recognized by Violentmonkey. The only exception is method 2.1, which recognizes any .js file because you explicitly drag it into the extension.

You can use any of these methods listed in the order of increasing complexity:

2.1. Drag the file into any Violentmonkey tab or popup

⚠ Only implemented in Chrome/Chromium 86 or newer and Violentmonkey 2.16 or newer.

⚡ In up-to-date Chrome you can improve performance of detection using the cutting edge FileSystemObserver API: navigate to chrome://flags/#enable-experimental-web-platform-features and enable the flag, then restart the browser. This is a one-time setup until the API becomes stable.

⚡ If you assigned a hotkey to activate Violentmonkey in the browser’s options for extensions, you can press it while dragging the file, which opens the extension’s popup into which you can drop the dragged file.

2.2. Drag the file into the browser toolbar or tab label area

  • In Chrome-like browsers you must enable “Allow access to file URLs” in Violentmonkey’s details in chrome://extensions page first. Since this is dangerous (any userscript will be able to read any local file via GM_xmlhttpRequest), you may want to use the other methods instead.

  • In modern Firefox-like browsers don’t close the tab of this file while tracking as it’s used to read the contents of the file.

2.3. Set up a server and navigate to http://localhost:8080/my-script.user.js

The port number :8080 may be different or even omitted depending on the server you installed.

A good server is indexzero/http-server. Once you install it, just type http-server -c5 at the directory of your script to start a server. The -c5 option sets cache time for max-age header to 5 seconds (more info), thus forcing a browser to query the server URL every 5 seconds. The caching can be disabled with -c-1 option.

If you want a UI, there are such servers as well, e.g. HTTP File Server for Windows.

⚠ Make sure the hostname is localhost and the script name ends with .user.js.

3. Enable tracking

Click Track external edits button to confirm installation and start tracking.

You can also make it the default button for local files by ticking the checkbox on the right, so it can be invoked via the hotkey shown in parentheses.

4. Edit the local file and save it

As long as the installer tab is open it will track your local file and install the new version automatically into Violentmonkey after you save the file. You can save it either manually or by configuring auto-save in the options of your editor.

  • The Stop tracking button may be useful for example when temporarily switching branches in your git repo. When finished, you can click Track external edits again.

  • The Reload tab option allows you to switch to another tab with a website matched by this script, so that this tab will be reloaded automatically when changes are detected and this script still matches the tab’s URL.

Known issues

  • Firefox may throttle detection: the older the file is, the longer it takes to detect the changes. See this report.

Published on