Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/standard/vscode-standard
VS Code extension for JavaScript Standard Style (`standard`) with automatic fixing
https://github.com/standard/vscode-standard
javascript nodejs standard vscode vscode-extension vscode-standardjs
Last synced: 3 months ago
JSON representation
VS Code extension for JavaScript Standard Style (`standard`) with automatic fixing
- Host: GitHub
- URL: https://github.com/standard/vscode-standard
- Owner: standard
- License: mit
- Created: 2016-09-27T11:14:55.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2023-09-16T07:31:25.000Z (over 1 year ago)
- Last Synced: 2024-06-11T18:05:09.365Z (8 months ago)
- Topics: javascript, nodejs, standard, vscode, vscode-extension, vscode-standardjs
- Language: TypeScript
- Homepage: https://marketplace.visualstudio.com/items?itemName=standard.vscode-standard
- Size: 9.13 MB
- Stars: 121
- Watchers: 4
- Forks: 24
- Open Issues: 25
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
vscode-standard
Visual Studio Code extension for JavaScript Standard Style with automatic fixing.## How to use
1. **Install the 'StandardJS - JavaScript Standard Style' extension**
Launch VSCode Quick Open (⌘+P), paste the following command, and press enter.
```text
ext install standard.vscode-standard
```For more information, take a look at the [documentation](https://code.visualstudio.com/docs/editor/extension-gallery#_browse-and-install-extensions).
2. **Install the engine `standard`, `semistandard`, `standardx` or `ts-standard`**
This can be done globally or locally. We recommend that you install them locally (i.e. saved in your project's `devDependencies`), to ensure that other developers have it installed when working on the project.
3. **Enable the extension**
That's it! The extension will automatically be enabled in projects that has one of the engines installed in `devDependencies` in `package.json`.
## Extension options
We give you some options to customize `vscode-standard` in your VSCode [`settings.json`](https://code.visualstudio.com/docs/getstarted/settings).
| Option | Description | Default |
| -------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------------- |
| `standard.enable` | enable or disable JavaScript Standard Style | `true` |
| `standard.enableGlobally` | enable or disable JavaScript Standard Style globally | `false` |
| `standard.run` | run linter `onSave` or `onType` | `onType` |
| `standard.autoFixOnSave` | enable or disable auto fix on save. It is only available when VSCode's `files.autoSave` is either `off`, `onFocusChange` or `onWindowChange`. It will not work with `afterDelay`. | `false` |
| `standard.nodePath` | use this setting if an installed `standard` package can't be detected. | `null` |
| `standard.validate` | an array of language identifiers specify the files to be validated | `["javascript", "javascriptreact", "typescript", "typescriptreact]` |
| `standard.workingDirectories` | an array for working directories to be used. | `[]` |
| `standard.engine` | You can use `semistandard`, `standardx` or `ts-standard` instead of `standard`. **Just make sure you've installed the `semistandard`, the `standardx` or the `ts-standard` package, instead of `standard`.** | `standard` |
| `standard.usePackageJson` | if set to `true`, JavaScript Standard Style will use project's `package.json` settings, otherwise globally installed `standard` module is used | `true` |
| `standard.treatErrorsAsWarnings` | Any linting error reported by Standard will instead be displayed as a warning within VS Code. | `false` |## Configuring Standard
You can still configure `standard` itself with the `standard.options` setting, for example:
```json
"standard.options": {
"globals": ["$", "jQuery", "fetch"],
"ignore": [
"node_modules/**"
],
"plugins": ["html"],
"parser": "babel-eslint",
"envs": ["jest"]
}
```It's recommended to change these options in your `package.json` file on a per-project basis, rather than setting them globally in `settings.json`. For example:
```json
"standard": {
"plugins": ["html"],
"parser": "babel-eslint"
}
```If you've got multiple projects within a workspace (e.g. you're inside a monorepo), VSCode prevents extensions from accessing multiple `package.json` files.
If you want this functionality, you should add each project folder to your workspace (`File -> Add folder to workspace...`). If you can't see this option, download the [VSCode Insiders Build](https://code.visualstudio.com/insiders/) to get the latest features.
### Commands
When you open the Command Palette in VSCode (⇧⌘P or Ctrl+Shift+P), this plugin has the following options:
- `Fix all auto-fixable problems` - applies JavaScript Standard Style auto-fix resolutions to all fixable problems.
- `Disable JavaScript Standard Style for this Workspace` - disable JavaScript Standard Style extension for this workspace.
- `Enable JavaScript Standard Style for this Workspace` - enable JavaScript Standard Style extension for this workspace.
- `Show output channel` - view the linter output for JavaScript Standard Style.### FAQ
1. How do I lint `script` tags in `vue` or `html` files?
You can lint them with `eslint-plugin-html`. Make sure it's installed, then enable linting for those file types in your `settings.json`:
```json
"standard.validate": [
"javascript",
"javascriptreact",
"html"
],
"standard.options": {
"plugins": ["html"]
},
"files.associations": {
"*.vue": "html"
},
```If you want to enable `autoFix` for the new languages, you should enable it yourself:
```json
"standard.validate": [
"javascript",
"javascriptreact",
{
"language": "html",
"autoFix": true
}
],
"standard.options": {
"plugins": ["html"]
}
```## How to develop
1. Fork this repo, and clone your fork locally.
2. Run `npm install` right under project root.
3. Open project in VSCode. The plugin should be disabled whilst developing.
4. Run the `watch` build task (⇧⌘B or Ctrl+Shift+B) to compile the client and server.
5. To run/debug the extension, use the `Launch Client` launch configuration (from the VSCode debug panel).
6. To debug the server, use the `Attach to Server` launch configuration.## How to package
1. Run `npm install`
2. Run `npm run package` to build a .vsix file
3. You can install it with `code --install-extension vscode-standard.vsix`## License
[MIT](./LICENSE)