feat(config): support configuring runtime compiler via app.config.compilerOptions

- `config.isCustomElement` is deprecated - use `app.config.compilerOptions.isCustomElement` instead.
This commit is contained in:
Evan You
2021-04-26 11:46:29 -04:00
parent b047a0864c
commit 091e6d67bf
4 changed files with 85 additions and 18 deletions

View File

@@ -69,7 +69,6 @@ export interface AppConfig {
performance: boolean
optionMergeStrategies: Record<string, OptionMergeFunction>
globalProperties: Record<string, any>
isCustomElement: (tag: string) => boolean
errorHandler?: (
err: unknown,
instance: ComponentPublicInstance | null,
@@ -80,6 +79,22 @@ export interface AppConfig {
instance: ComponentPublicInstance | null,
trace: string
) => void
/**
* @deprecated use config.compilerOptions.isCustomElement
*/
isCustomElement?: (tag: string) => boolean
/**
* Options to pass to @vue/compiler-dom.
* *Only supported in runtime compiler build.*
*/
compilerOptions: {
isCustomElement: (tag: string) => boolean
whitespace?: 'preserve' | 'condense'
comments?: boolean
delimiters?: [string, string]
}
}
export interface AppContext {
@@ -122,9 +137,11 @@ export function createAppContext(): AppContext {
performance: false,
globalProperties: {},
optionMergeStrategies: {},
isCustomElement: NO,
errorHandler: undefined,
warnHandler: undefined
warnHandler: undefined,
compilerOptions: {
isCustomElement: NO
}
},
mixins: [],
components: {},

View File

@@ -727,18 +727,22 @@ export function finishComponentSetup(
if (__DEV__) {
startMeasure(instance, `compile`)
}
const compilerOptions: CompilerOptions = {
isCustomElement: instance.appContext.config.isCustomElement,
delimiters: Component.delimiters
}
const { isCustomElement, compilerOptions } = instance.appContext.config
const finalCompilerOptions: CompilerOptions = extend(
{
isCustomElement: isCustomElement || NO,
delimiters: Component.delimiters
},
compilerOptions
)
if (__COMPAT__) {
// pass runtime compat config into the compiler
compilerOptions.compatConfig = Object.create(globalCompatConfig)
finalCompilerOptions.compatConfig = Object.create(globalCompatConfig)
if (Component.compatConfig) {
extend(compilerOptions.compatConfig, Component.compatConfig)
extend(finalCompilerOptions.compatConfig, Component.compatConfig)
}
}
Component.render = compile(template, compilerOptions)
Component.render = compile(template, finalCompilerOptions)
if (__DEV__) {
endMeasure(instance, `compile`)
}