English | 简体中文
Prepends file name and line numbers for each logger command, based on the source files.
// src/view/app.js
class App() {
constructor() {
logger.log('test')//line no 20,column no 10
}
}
↓ ↓ ↓ ↓ ↓ ↓
class App() {
constructor() {
logger.log('[s.V/app.js (20:10)]', 'test')
}
}
$ yarn add babel-plugin-logger-source -D
.babelrc
{
"plugins": [
["logger-source"]
]
}
.babelrc
{
"plugins": [
["logger-source",{
logger: string[];
prefix: string;
resolveFileName: Function | 'acronyms' | 'fullpath';
}]
]
}
Prepends for these command. defaults:
{
//...
logger: [
'logger.log',
'logger.info',
'logger.wran',
'logger.error',
'logger.debug',
];
}
prefix before filename.
example: prefix:crm-client
。
logger.info('test');
↓ ↓ ↓ ↓ ↓ ↓
logger.info('crm-client [s.V/app.js (20:10)]', 'test')
revolve the filename. support:fullpath
,acronyms
or custome function.default acronyms
。
acronyms
// src\\View/app.js
logger.info('test');
↓ ↓ ↓ ↓ ↓ ↓
logger.info('[s.V/app.js (20:10)]', 'test')
fullpath
// src\\View/app.js
logger.info('test');
↓ ↓ ↓ ↓ ↓ ↓
logger.info('[s.V/app.js (20:10)]', 'test')
// src\\View/app.js
logger.info('test');
↓ ↓ ↓ ↓ ↓ ↓
logger.info('[src\\View\\app.js (2:10)]', 'test')
Custom Fuction
((params: ResolveFileNameParams) => string)
params:
{
filename: string; //file name
projectPath: string; //project path
prefix: string; //the prefix config in babelrc
line: number; //line no
column: number; //column no
}
example:
{
"plugins": [
["logger-source",{
resolveFileName:function(params){
return params.filename;
}
}]
]
}