fix(compiler-dom): should ignore and warn side effect tags like script and style
This keeps behavior consistency with v2.
This commit is contained in:
parent
903e8f697e
commit
5e52f4e4d7
@ -0,0 +1,27 @@
|
|||||||
|
import { compile, CompilerError } from '../../src'
|
||||||
|
|
||||||
|
describe('compiler: ignore side effect tags', () => {
|
||||||
|
it('should ignore script', () => {
|
||||||
|
let err: CompilerError | undefined
|
||||||
|
const { code } = compile(`<script>console.log(1)</script>`, {
|
||||||
|
onError(e) {
|
||||||
|
err = e
|
||||||
|
}
|
||||||
|
})
|
||||||
|
expect(code).not.toMatch('script')
|
||||||
|
expect(err).toBeDefined()
|
||||||
|
expect(err!.message).toMatch(`Tags with side effect`)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should ignore style', () => {
|
||||||
|
let err: CompilerError | undefined
|
||||||
|
const { code } = compile(`<style>h1 { color: red }</style>`, {
|
||||||
|
onError(e) {
|
||||||
|
err = e
|
||||||
|
}
|
||||||
|
})
|
||||||
|
expect(code).not.toMatch('style')
|
||||||
|
expect(err).toBeDefined()
|
||||||
|
expect(err!.message).toMatch(`Tags with side effect`)
|
||||||
|
})
|
||||||
|
})
|
@ -31,6 +31,7 @@ export const enum DOMErrorCodes {
|
|||||||
X_V_MODEL_UNNECESSARY_VALUE,
|
X_V_MODEL_UNNECESSARY_VALUE,
|
||||||
X_V_SHOW_NO_EXPRESSION,
|
X_V_SHOW_NO_EXPRESSION,
|
||||||
X_TRANSITION_INVALID_CHILDREN,
|
X_TRANSITION_INVALID_CHILDREN,
|
||||||
|
X_IGNORED_SIDE_EFFECT_TAG,
|
||||||
__EXTEND_POINT__
|
__EXTEND_POINT__
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -44,5 +45,6 @@ export const DOMErrorMessages: { [code: number]: string } = {
|
|||||||
[DOMErrorCodes.X_V_MODEL_ON_FILE_INPUT_ELEMENT]: `v-model cannot used on file inputs since they are read-only. Use a v-on:change listener instead.`,
|
[DOMErrorCodes.X_V_MODEL_ON_FILE_INPUT_ELEMENT]: `v-model cannot used on file inputs since they are read-only. Use a v-on:change listener instead.`,
|
||||||
[DOMErrorCodes.X_V_MODEL_UNNECESSARY_VALUE]: `Unnecessary value binding used alongside v-model. It will interfere with v-model's behavior.`,
|
[DOMErrorCodes.X_V_MODEL_UNNECESSARY_VALUE]: `Unnecessary value binding used alongside v-model. It will interfere with v-model's behavior.`,
|
||||||
[DOMErrorCodes.X_V_SHOW_NO_EXPRESSION]: `v-show is missing expression.`,
|
[DOMErrorCodes.X_V_SHOW_NO_EXPRESSION]: `v-show is missing expression.`,
|
||||||
[DOMErrorCodes.X_TRANSITION_INVALID_CHILDREN]: `<Transition> expects exactly one child element or component.`
|
[DOMErrorCodes.X_TRANSITION_INVALID_CHILDREN]: `<Transition> expects exactly one child element or component.`,
|
||||||
|
[DOMErrorCodes.X_IGNORED_SIDE_EFFECT_TAG]: `Tags with side effect (<script> and <style>) are ignored in client component templates.`
|
||||||
}
|
}
|
||||||
|
@ -18,6 +18,7 @@ import { transformOn } from './transforms/vOn'
|
|||||||
import { transformShow } from './transforms/vShow'
|
import { transformShow } from './transforms/vShow'
|
||||||
import { warnTransitionChildren } from './transforms/warnTransitionChildren'
|
import { warnTransitionChildren } from './transforms/warnTransitionChildren'
|
||||||
import { stringifyStatic } from './transforms/stringifyStatic'
|
import { stringifyStatic } from './transforms/stringifyStatic'
|
||||||
|
import { ignoreSideEffectTags } from './transforms/ignoreSideEffectTags'
|
||||||
import { extend } from '@vue/shared'
|
import { extend } from '@vue/shared'
|
||||||
|
|
||||||
export { parserOptions }
|
export { parserOptions }
|
||||||
@ -43,7 +44,14 @@ export function compile(
|
|||||||
return baseCompile(
|
return baseCompile(
|
||||||
template,
|
template,
|
||||||
extend({}, parserOptions, options, {
|
extend({}, parserOptions, options, {
|
||||||
nodeTransforms: [...DOMNodeTransforms, ...(options.nodeTransforms || [])],
|
nodeTransforms: [
|
||||||
|
// ignore <script> and <tag>
|
||||||
|
// this is not put inside DOMNodeTransforms because that list is used
|
||||||
|
// by compiler-ssr to generate vnode fallback branches
|
||||||
|
ignoreSideEffectTags,
|
||||||
|
...DOMNodeTransforms,
|
||||||
|
...(options.nodeTransforms || [])
|
||||||
|
],
|
||||||
directiveTransforms: extend(
|
directiveTransforms: extend(
|
||||||
{},
|
{},
|
||||||
DOMDirectiveTransforms,
|
DOMDirectiveTransforms,
|
||||||
|
15
packages/compiler-dom/src/transforms/ignoreSideEffectTags.ts
Normal file
15
packages/compiler-dom/src/transforms/ignoreSideEffectTags.ts
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
import { NodeTransform, NodeTypes, ElementTypes } from '@vue/compiler-core/src'
|
||||||
|
import { DOMErrorCodes, createDOMCompilerError } from '../errors'
|
||||||
|
|
||||||
|
export const ignoreSideEffectTags: NodeTransform = (node, context) => {
|
||||||
|
if (
|
||||||
|
node.type === NodeTypes.ELEMENT &&
|
||||||
|
node.tagType === ElementTypes.ELEMENT &&
|
||||||
|
(node.tag === 'script' || node.tag === 'style')
|
||||||
|
) {
|
||||||
|
context.onError(
|
||||||
|
createDOMCompilerError(DOMErrorCodes.X_IGNORED_SIDE_EFFECT_TAG, node.loc)
|
||||||
|
)
|
||||||
|
context.removeNode()
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user