JavaScript Standard Style
Sponsored by
English • Español (Latinoamérica) • Français • Bahasa Indonesia • Italiano (Italian) • 日本語 (Japanese) • 한국어 (Korean) • Português (Brasil) • 简体中文 (Simplified Chinese) • 繁體中文 (Taiwanese Mandarin)
Guida allo stile JavaScript, con linter e autocorrettore del codice
Questo modulo fa risparmiare tempo a te (e altri!) in tre modi:
- Nessuna configurazione La maniera più veloce per rafforzare un stile consistente nel tuo progetto. Basta solo installarlo.
- Codice automatica formattato Esegui solamente
standard --fix
e puoi dire addio a tutto quel codice inconsistente e disordinato. - Trova errori di stile ed errori di programmazione Risparmia tempo durante i controlli del codice senza fare avanti e indietro tra i vari collaboratori
Non ci sono decisioni da prendere. Nessun .eslintrc
, jshintrc
, o .jscsrc
file da mantenere.
Funziona e basta.
Installa con:
npm install standard --save-dev
Le regole
- 2 spazi per indentare
- Singolo apostrofo per le stringhe - eccetto per evitare l'escaping
- Nessuna variabile non utilizzata - questo cattura molti errori!
- Nessun punto e virgola È OK. Davvero!
- Mai iniziare una linea di codice con
(
,[
, or`
- Questa è l'unica scappatoia per omettere i punto e virgola automaticamente controllato per te!
- Maggiori dettagli
- Spazio dopo le parole chiave
if (condition) { ... }
- Spazio dopo il nome di una funzione
function name (arg) { ... }
- Usare sempre
===
invece di==
maobj == null
è consentito per controllarenull || undefined
. - Sempre gestire l'errore node.js
err
dato come parametro da una funzione - Usare sempre il prefisso per le variabili globali del browser con
window
- eccezione perdocument
enavigator
- Previene l'uso di nomi riservati per le variabili globali del browser, come ad esempio
open
,length
,event
, ename
.
- Previene l'uso di nomi riservati per le variabili globali del browser, come ad esempio
- E ancora di più prova
standard
, oggi!
Per avere le idee più chiari, da un'occhiata al
file d'esempio scritto
usando JavaScript Standard Style. O guarda i
millemila progetti
che usano standard
!
Tabella dei contenuti
- Settaggio veloce
- FAQ
- Perchè dovrei usare JavaScript Standard Style?
- Chi usa JavaScript Standard Style?
- Ci sono dei plugin per gli editor di testo?
- Esiste un banner?
- Non sono d'accordo con la regola X, posso cambiarla?
- Ma questo non è un vero web standard!
- Esiste un formattatore automatico?
- Come posso ignorare dei file?
- Come posso nascondere un determinato avviso?
- Come posso nascondere un determinato warning?
- Utilizzo una libreria che inquina il namespace globale. Come posso prevenire errori del tipo "variable is not defined"?
- Come posso usare funzionalità sperimentali di JavaScript (ES Next)?
- Posso usare varianti di JavaScript come Flow?
- Riguardo Mocha, Jasmine, QUnit, ecc.?
- Riguardo Web Workers?
- Posso controllare codice dentro file di tipo Markdown o HTML?
- C'è un hook Git per
pre-commit
? - Come posso mostrare l'output del mio codice colorato e carino?
- C'è un API per Node.js?
- Come posso contribuire a
standard
?
- Licenza
Installazione
La maniera più semplice per usare JavaScript Standard Style è quella di installarlo globalmente usando la linea di comando di Node. Esegui il seguente comando da terminale:
$ npm install standard --global
O, se vuoi installare standard
localmente, da utilizzare in un singolo progetto:
$ npm install standard --save-dev
Nota: per eseguire i precedenti comandi, Node.js and npm deve essere già installato sulla propria macchina.
Utilizzo
Dopo aver installato standard
, dovresti essere in grado di utilizzarlo come programma. Lo scenario d'uso più comune sarebbe quello di
controllare lo stile di tutti i tuoi file JavaScript attualmente presenti nel tuo progetto:
$ standard
Error: Use JavaScript Standard Style
lib/torrent.js:950:11: Expected '===' and instead saw '=='.
Puoi opzionalmente passare una cartella (o cartelle) usando il pattern globale. Assicurati di mettere
tra virgolette i percorsi contenenti il pattern globale, così verranno espansi da standard
invece che dalla tua shell:
$ standard "src/util/**/*.js" "test/**/*.js"
Nota: di default standard
controllerà tutti i file che corrispondono al seguente pattern:
**/*.js
, **/*.jsx
.
Cosa vorresti fare se sei intelligente
-
Aggiungerlo al tuo
package.json
{ "name": "my-cool-package", "devDependencies": { "standard": "*" }, "scripts": { "test": "standard && node my-tests.js" } }
-
Lo stile del tuo codice verrà controllato automaticamente quando esegui
npm test
$ npm test Error: Use JavaScript Standard Style lib/torrent.js:950:11: Expected '===' and instead saw '=='.
-
Mai più suggerimenti riguardo lo stile del tuo codice durante le pull request!
Perchè dovrei usare JavaScript Standard Style?
La bellezza di JavaScript Standard Style è la sua semplicità. Nessuno vuole mantenere migliaia di linee di codice di configurazione per lo stile del codice per ogni progetto/module sul quale si lavora. Basta impazzire!
Questo modulo fa risparmiare tempo a te (e altri!) in tre modi:
-
Nessuna configurazione La maniera più veloce per rafforzare un stile consistente nel tuo progetto. Basta solo installarlo.
-
Codice automatica formattato Esegui solamente
standard --fix
e puoi dire addio a tutto quel codice inconsistente e disordinato. -
Trova errori di stile ed errori di programmazione Risparmia tempo durante i controlli del codice senza fare avanti e indietro tra i vari collaboratori
Adottare lo stile
standard
signica dare più importanza alla chiarezza del codice e convenzioni della comunità rispetto che allo stile personale. Questo non potrebbe avere senso per il 100% dei progetti e modi di sviluppo, ma l'open source può essere un posto ostile per i nuovi arrivati. Decidere le aspettative dei collaboratori in modo chiaro e automatizzato rendere un progetto più sano.
Chi usa JavaScript Standard Style?
Un sacco di gente!
Your logo here | Your logo here | Your logo here |
---|
Oltre alle aziende, anche molti membri della comunità usano standard
su pacchetti che sono troppo numerosi da mostrare qui.
standard
è inoltre il miglior linter favorito dal caso d'uso dalla GitHub Clean Code Linter.
Ci sono dei plugin per gli editor di testo?
Primo, installa standard
. Dopo di che installa il plugin più appropriato per il tuo editor:
Sublime Text
Usano Package Control, installa SublimeLinter e SublimeLinter-contrib-standard.
Per la formattazione automatica durante il salvataggio, installa StandardFormat.
Atom
Installa linter-js-standard.
In alternativa, puoi installare linter-js-standard-engine. Invece di installare la sua versione di standard
, userà automaticamente la version installata all'interno del tuo progetto. Funzionerà automaticamente anche con altri linters che si basano su standard-engine.
Per la formattazione automatica, installa standard-formatter. Per aiuti (snippets), installa standardjs-snippets.
Visual Studio Code
Installa vscode-standard. (Include supporto per la formattazione automatica.)
Per JS snippets, installa: vscode-standardjs-snippets. Per ReactJS snippets, installa vscode-react-standard.
Vim
Installa ale.
Per la formattazione automatica al salvataggio, aggiungi quelle linee a .vimrc
:
autocmd bufwritepost *.js silent !standard --fix %
set autoread
Pacchetti alternativi che possono essere inclusi sono neomake e syntastic, entrambi hanno all'interno il supporto per standard
(configurazione potrebbe essere necessaria).
Emacs
Installa Flycheck e controlla manual per imparare come abilitarlo all'interno del tuo progetto.
Brackets
Cerca l'estenzione di registro per "Standard Code Style" and clicca "Install".
WebStorm (PhpStorm, IntelliJ, RubyMine, JetBrains, etc.)
WebStorm ha annunciato recentemente supporto nativo
per standard
direttamente nell'IDE.
Se preferisci configurare standard
manualmente, segui questa guida. Questa guida va bene per tutti i prodotti JetBrains, come ad esempio PhpStorm, IntelliJ, RubyMine, ecc.
Esiste un banner?
Sì! Se usi standard
nel tuo progetto, puoi includere uno di questi banner nel tuo readme file per far sapere alle persone the il tuo codice usa JavaScript Standard Style.
[![JavaScript Style Guide](https://cdn.rawgit.com/standard/standard/master/badge.svg)](https://github.com/standard/standard)
[![JavaScript Style Guide](https://img.shields.io/badge/code_style-standard-brightgreen.svg)](https://standardjs.com)
Non sono d'accordo con la regola X, posso cambiarla?
No. Il punto essenziale di standard
è di aiutarti a salvare tempo evitando bikeshedding (discussioni su piccole cose mentre la cosa più importante non è terminata) sullo stile del codice. Ci sono un sacco di grandi discussioni riguardo tabs vs. spazi, ecc. che non saranno mai risolte. Queste discussioni semplicemente fanno perdere tempo. Alla fine, quello che ti rimane da fare è solamente 'scegli qualcosa', è questa la filosofia di standard
- un sensato insieme di opinioni di 'scegli qualcosa'. Con un po' di fiducia, gli utenti vedranno il valore in ciò invece di difendere il proprie opinioni personali.
Se davvero vuoi configurare centinaia di regole ESLint individualmente, puoi sempre usare eslint
direttamente con eslint-config-standard in modo da usare le tue regole.
Suggerimento: usa semplicemente standard
e vai avanti. Ci sono problemi più reali dove puoi spendere il tuo prezioso tempo! :P
Ma questo non è un vero web standard!
Ovvio che no! Lo stile presentato qui non è affiliato con nessuno degli gruppi standard web, ecco perchè questo repository si chiama standard/standard
e non ECMA/standard
.
La parola "standard" signica più di un "web standard" :-) Per esempio:
- Questo module aiuta a tenere il codice vicino ad uno standard di qualità
- Questo module assicura che nuovi contribtori seguano gli stili standard
Esiste un formattatore automatico?
Sì! Puoi usare standard --fix
per correggere la maggior parte degli errori automaticamente.
standard --fix
è direttamente offerto da standard
per offrire il massimo della convenienza. La maggior parte degli errori possono essere corretti, ma alcuni errori (come ad esempio dimenticarsi di gestire gli errori) devono essere corretti a mano.
Per risparmiare tempo, l'ouput di standard
è un messaggio del tipo "Run standard --fix to automatically fix some problems
" quando rileva problemi che possono essere risolti automaticamente.
Come posso ignorare dei file?
Alcuni percorsi (node_modules/
, coverage/
, vendor/
, *.min.js
, bundle.js
,
e file/cartelle the iniziano con .
come .git/
) sono automaticamente ignorati.
Anche i percorsi specificati all'interno del file .gitignore
sono automaticamente ignorati.
Alle volte hai bisogno di ignorare file minificati o cartelle in più. Per farlo, aggiungi la proprietà standard.ignore
all'interno di package.json
:
"standard": {
"ignore": [
"**/out/",
"/lib/select2/",
"/lib/ckeditor/",
"tmp.js"
]
}
Come posso nascondere un determinato avviso?
In rari casi, avarai la necessità di rompere le regole e nascondere l'avviso generato da standard
.
JavaScript Standard Style usa ESLint al di sotto del suo engine e puoi nascondere gli avvisi come se lo facessi direttamente per ESLint.
Disabilita tutte le regole in una specifica riga:
file = 'So cosa sto facendo' // eslint-disable-line
O, disabilita solo la regola "no-use-before-define"
:
file = 'So cosa sto facendo' // eslint-disable-line no-use-before-define
O, disabilita la regola "no-use-before-define"
per più righe:
/* eslint-disable no-use-before-define */
console.log('offending code goes here...')
console.log('offending code goes here...')
console.log('offending code goes here...')
/* eslint-enable no-use-before-define */
Utilizzo una libreria che inquina il namespace globale. Come posso prevenire errori del tipo "variable is not defined"?
Alcune librerie (es. mocha
) mettono le loro funzionalità (es. describe
, it
) nell'oggetto globale. Considerato il fatto che queste funzioni definite o non sono importate usando il require
all'interno del tuo codice, standard
vi avviserà che stai per utilizzare una variabile che non è non stata definita. (di solito questa regola è utile per trovare errori di scrittura!). Ma vogliamo disabilitarlo per questi oggetti globali.
Per permettere a standard
(anche per quando qualcun altro leggerà il tuo codice) di far sapere che certe variabili sono globali all'interno del tuo codice, aggiungi questo all'inizio del tuo file:
/* global myVar1, myVar2 */
Se hai centiaia di file, sarebbe più conveniente evitare di aggiungere commenti su ogni file. In questo caso, esegui:
$ standard --global myVar1 --global myVar2
Oppure aggiungi questo al tuo package.json
:
{
"standard": {
"globals": [ "myVar1", "myVar2" ]
}
}
Nota: global
e globals
sono equivalenti.
Come posso usare funzionalità sperimentali di JavaScript (ES Next)?
standard
supporta le ultime funzionalità di ECMAScript, ES8 (ES2017), includendo anche funzionalità proposte (proposals) che si trovano allo "Stage 4" del processo decisionale.
Per supportare funzionalità sperimentali, standard
permette di configurare uno perser JavaScript su misura (custom). Prima di aggiungere un diverso parser, considera se la complessità che si andrà ad aggiungere ne valga la pena.
Per usare un parser su misura (custom), installalo da npm (esempio: npm install --save-dev @babel/eslint-parser
) ed esegui:
$ standard --parser @babel/eslint-parser
Oppure aggiungi questo al tuo package.json
:
{
"standard": {
"parser": "@babel/eslint-parser"
}
}
Se standard
è installato globalmente (i.e. npm install standard --global
), allora assicurati che anche @babel/eslint-parser
sia installato globalmente, con
npm install @babel/eslint-parser --global
.
Posso usare varianti di JavaScript come Flow?
Prima di usare una variante di JavaScript, considera se l'aggiunta di complessità (ed energie richieste per permettere i nuovi sviluppatori di essere pronti) ne valga la pena.
standard
supporta plugins ESLint. Utilizza uno di questi plugins per trasformare il codice in valido JavaScript prima che standard
lo veda. Per usare un parser ad-hoc, installalo tramite npm ed esegui:
$ standard --plugin PLUGIN_NAME
Oppure aggiungi questo al tuo package.json
:
{
"standard": {
"plugins": [ "PLUGIN_NAME" ]
}
}
Per usare Flow, hai bisogno di usare @babel/eslint-parser
come parser, Quindi, esegui npm install eslint-plugin-flowtype @babel/eslint-parser
e dopo di che esegui:
$ standard --plugin flowtype --parser @babel/eslint-parser
Oppure aggiungi questo al tuo package.json
:
{
"standard": {
"plugins": [ "flowtype" ],
"parser": "@babel/eslint-parser"
}
}
Se standard
è installato globalmente (es. npm install standard --global
), allora assicurati che anche eslint-plugin-flowtype
sia installato globalmente, con
npm install eslint-plugin-flowtype --global
.
Nota: plugin
e plugins
sono equivalenti.
Riguardo Mocha, Jasmine, QUnit, ecc.?
Per supportare mocha nei tuoi file di test, aggiungi questo all'inizio dei tuoi file:
/* eslint-env mocha */
O esegui:
$ standard --env mocha
Dove mocha
può essere anche jasmine
, qunit
, phantomjs
, e così via. Per vedere l'intera lista, controlla la documentazione di ESlint su come
specificare degli ambienti. Per una lista completa degli oggetti globali a disposizione degli ambienti, controlla la sezione
globals del modulo npm.
Nota: env
e envs
sono equivalenti.
Riguardo Web Workers?
Aggiungi questo all'inizio del tuo file:
/* eslint-env serviceworker */
Per permettere a standard
(anche per quando qualcun altro leggerà il tuo codice) di far sapere
che self
è un oggetto globale all'interno del codice del tuo web worker.
Posso controllare codice dentro file di tipo Markdown o HTML?
Per controllare codice all'interno di file di tipo Markdown, usa standard-markdown
.
In alternativa, ci sono diversi plugin di ESLint per controllare il codice all'interno di Markdown, HTML e altri tipi di file:
Per controllare il codice dentro un file Markdown, usa il plugin ESLint:
$ npm install eslint-plugin-markdown
Dopodiche, per controllare codice JavaScript che compare dentro un blocco di codice, esegui:
$ standard --plugin markdown '**/*.md'
Per controllare codice dentro file HTML, usa il plugin ESLint:
$ npm install eslint-plugin-html
Dopodiche, per controllare codice JavaScript che compare dentro i tag <script>
, esegui:
$ standard --plugin html '**/*.html'
C'è un hook Git per pre-commit
?
Divertente!
#Assicurati che tutti i file javascript pronti per il commit passano lo standard code style
function xargs-r() {
# Portable version of "xargs -r". The -r flag is a GNU extension that
# prevents xargs from running if there are no input files.
if IFS= read -r -d $'\n' path; then
echo "$path" | cat - | xargs "$@"
fi
}
git diff --name-only --cached --relative | grep '\.jsx\?$' | sed 's/[^[:alnum:]]/\\&/g' | xargs-r -E '' -t standard
if [[ $? -ne 0 ]]; then
echo 'JavaScript Standard Style errors were detected. Aborting commit.'
exit 1
fi
Come posso mostrare l'output del mio codice colorato e carino?
L'output all'interno della libreria è alquanto basilare, ma se ti piacciono le cose sfarzose, allora installa snazzy:
$ npm install snazzy
Ed esegui:
$ standard | snazzy
Ci sono anche standard-tap, standard-json, standard-reporter, e standard-summary.
C'è un API per Node.js?
Sì!
async standard.lintText(text, [opts])
Esegue il lint sul parametro passato come input text
. Il parametro opts
è un oggetto con le seguenti opzioni:
{
// unique to lintText
filename: '', // path of file containing the text being linted
// common to lintText and lintFiles
cwd: '', // current working directory (default: process.cwd())
fix: false, // automatically fix problems
extensions: [], // file extensions to lint (has sane defaults)
globals: [], // custom global variables to declare
plugins: [], // custom eslint plugins
envs: [], // custom eslint environment
parser: '', // custom js parser (e.g. babel-eslint)
usePackageJson: true, // use options from nearest package.json?
useGitIgnore: true // use file ignore patterns from .gitignore?
}
Ulteriori opzioni possono essere caricate usando package.json
se si trova all'interno della cartella del tuo progetto.
L'oggetto results
conterrà se seguenti proprietà:
const results = {
results: [
{
filePath: '',
messages: [
{ ruleId: '', message: '', line: 0, column: 0 }
],
errorCount: 0,
warningCount: 0,
output: '' // fixed source code (only present with {fix: true} option)
}
],
errorCount: 0,
warningCount: 0
}
async standard.lintFiles(files, [opts])
Esegue il lint sui files
glob. È possibile passare un oggetto opts
:
{
// unique to lintFiles
ignore: [], // file globs to ignore (has sane defaults)
// common to lintText and lintFiles
cwd: '', // current working directory (default: process.cwd())
fix: false, // automatically fix problems
extensions: [], // file extensions to lint (has sane defaults)
globals: [], // custom global variables to declare
plugins: [], // custom eslint plugins
envs: [], // custom eslint environment
parser: '', // custom js parser (e.g. babel-eslint)
usePackageJson: true, // use options from nearest package.json?
useGitIgnore: true // use file ignore patterns from .gitignore?
}
Oggetto results
. (lo stesso di prima).
Come posso contribuire a standard
?
I collaboratori sono i benvenuti! Controlla le issue o le PR e crea la tua di PR se vuoi qualcosa che non vedi.
Vuoi chattare? Unisciti ai collaboratori su IRC nel canale #standard
su freenode.
Eccoti importanti module che sono importanti nell'ecosistema di standard
:
- standard - questo repository
- standard-engine - motore cli per regole eslint arbitrarie
- eslint-config-standard - regole eslint per standard
- eslint-config-standard-jsx - regole eslint per standard (JSX)
- eslint-plugin-standard - regole eslint personalizzate per standard (non fanno parte del cuore di eslint)
- eslint - il linter che da energie a standard
- snazzy - generate output carino nel terminale per standard
- standard-www - codice per https://standardjs.com
- semistandard - standard, ma con i punti e virgola (se proprio sei obbligato)
Ci sono anche molti plugin per l'editor di testo, una lista di npm packages che usano standard
,
una incredibile lista di
packages nell'ecosistema di standard
.
Licenza
MIT. Copyright (c) Feross Aboukhadijeh.