Simple vue file support for Node.js. Mainly for testing purposes.
Template block will be parsed and compiled to a render function which allows us early detection of some possible problems with the template. Script block will be parsed and possibly can go through babel transpilation step. Style block will be ignored and won't be processed for now.
Source maps are supported, both the vue parser (for external script files we generate one) and babel returns source maps which will be merged and inlined in the compiled vue file.
npm install --save-dev @prepair/require-extension-vue
Can be used the same way as @babel/register.
require('@prepair/require-extension-vue')
const SomeComponent = require('src/components/SomeComponent.vue')
// ...
// do something with the parsed and compiled `SomeComponent`
// enabling permanent caching and babel
require('@prepair/require-extension-vue')({
permanentCache: true,
babel: true
})
const OtherComponent = require('src/components/OtherComponent.vue')
// ...
// do something with the parsed and compiled `OtherComponent`
mocha --require @prepair/require-extension-vue test
name | type | default | description |
---|---|---|---|
babel | boolean / object | false | if true or non empty object then it will transpile the script block via babel. true means that babel will try to load your babel configuration if found otherwise will fallback to babel-preset-env set to current node setting. Via object value you can provide any valid option to babel which could override/extend your babel configuration too. |
logLevel | string | warn | logging level: trace /debug /info /warn /error /silent . note that this one can be overriden by REQ_EXT_VUE_LOG_LEVEL |
noLogParserErrors | boolean | false | if true no parser errors will be logged in console |
noLogTemplateCompilerErrors | boolean | false | if true no template compiler errors will be logged in console |
noLogTemplateCompilerTips | boolean | false | if true no template compiler tips will be logged in console |
parser.errors.exclude | array | [] | excludes for parser error logs. string or RegExp values are supported. string values will be compared as is, RegExp will call .test(error) |
permanentCache | boolean | false | if true enables permanent caching of compiled vue files on the disk |
templateCompiler.errors.exclude | array | [] | excludes for template compiler error logs. string or RegExp values are supported. string values will be compared as is, RegExp will call .test(error) |
templateCompiler.tips.exclude | array | [] | excludes for template compiler tip logs. string or RegExp values are supported. string values will be compared as is, RegExp will call .test(tip) |
// enable permanent cache
require('@prepair/require-extension-vue')({
permanentCache: true
})
// enable babel transpilation of script block
require('@prepair/require-extension-vue')({
babel: true
})
// enable permanent cache + setup babel with custom options
require('@prepair/require-extension-vue')({
permanentCache: true,
babel: {
presets: [
[
'@babel/preset-env',
{
targets: 'current node'
}
]
]
}
})
name | description |
---|---|
REQ_EXT_VUE_LOG_LEVEL | values can be trace , debug , info , warn , error and silent . for example if set to info then all errors, warnings and info messages will be logged in the console. the default log level is warn . if set it will override the logLevel option |
REQ_EXT_VUE_SILENCE_PARSER_ERRORS | if set to any value, no parser error will be logged in the console. if noLogParserErrors is true then this won't have any effect |
REQ_EXT_VUE_SILENCE_TEMPLATE_COMPILER_TIPS | if set to any value, no template compiler error will be logged in the console. if noLogTemplateCompilerErrors is true then this won't have any effect |
REQ_EXT_VUE_SILENCE_TEMPLATE_COMPILER_ERRORS | if set to any value, no template compiler tip will be logged in the console. if noLogTemplateCompilerTips is true then this won't have any effect |
# set log level to `debug`
REQ_EXT_VUE_LOG_LEVEL=debug npm test
# silence parser and template compiler errors
# (value can be any string)
REQ_EXT_VUE_SILENCE_PARSER_ERRORS=true REQ_EXT_VUE_SILENCE_TEMPLATE_COMPILER_ERRORS=dummy npm test
npm test
Taken some ideas from the following projects. Some of them are more robust and supports more use cases. Feel free to check them out.
- @babel/register
- jackmellis/require-extension-hooks-vue and require-extension-hooks
- lixinliang/require-extension-vue
- vue-loader
- Node.js : >= 14.18.3
- npm : ^8.4.1