Skip to content

Commit

Permalink
feat(compiler-sfc): allow using :deep, :global & :slotted for short i…
Browse files Browse the repository at this point in the history
…n `<style scoped>`
  • Loading branch information
yyx990803 committed Jul 10, 2020
1 parent bd5c3b9 commit f3cc41f
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 3 deletions.
14 changes: 14 additions & 0 deletions packages/compiler-sfc/__tests__/compileStyle.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,10 @@ describe('SFC scoped CSS', () => {
})

test('::v-deep', () => {
expect(compileScoped(`:deep(.foo) { color: red; }`)).toMatchInlineSnapshot(`
"[test] .foo { color: red;
}"
`)
expect(compileScoped(`::v-deep(.foo) { color: red; }`))
.toMatchInlineSnapshot(`
"[test] .foo { color: red;
Expand All @@ -78,6 +82,11 @@ describe('SFC scoped CSS', () => {
})

test('::v-slotted', () => {
expect(compileScoped(`:slotted(.foo) { color: red; }`))
.toMatchInlineSnapshot(`
".foo[test-s] { color: red;
}"
`)
expect(compileScoped(`::v-slotted(.foo) { color: red; }`))
.toMatchInlineSnapshot(`
".foo[test-s] { color: red;
Expand All @@ -96,6 +105,11 @@ describe('SFC scoped CSS', () => {
})

test('::v-global', () => {
expect(compileScoped(`:global(.foo) { color: red; }`))
.toMatchInlineSnapshot(`
".foo { color: red;
}"
`)
expect(compileScoped(`::v-global(.foo) { color: red; }`))
.toMatchInlineSnapshot(`
".foo { color: red;
Expand Down
7 changes: 4 additions & 3 deletions packages/compiler-sfc/src/stylePluginScoped.ts
Original file line number Diff line number Diff line change
Expand Up @@ -44,9 +44,10 @@ export default postcss.plugin('vue-scoped', (options: any) => (root: Root) => {
}

if (n.type === 'pseudo') {
const { value } = n
// deep: inject [id] attribute at the node before the ::v-deep
// combinator.
if (n.value === '::v-deep') {
if (value === ':deep' || value === '::v-deep') {
if (n.nodes.length) {
// .foo ::v-deep(.bar) -> .foo[xxxxxxx] .bar
// replace the current node with ::v-deep's inner selector
Expand Down Expand Up @@ -81,7 +82,7 @@ export default postcss.plugin('vue-scoped', (options: any) => (root: Root) => {
// slot: use selector inside `::v-slotted` and inject [id + '-s']
// instead.
// ::v-slotted(.foo) -> .foo[xxxxxxx-s]
if (n.value === '::v-slotted') {
if (value === ':slotted' || value === '::v-slotted') {
rewriteSelector(n.nodes[0] as Selector, true /* slotted */)
selector.insertAfter(n, n.nodes[0])
selector.removeChild(n)
Expand All @@ -93,7 +94,7 @@ export default postcss.plugin('vue-scoped', (options: any) => (root: Root) => {

// global: replace with inner selector and do not inject [id].
// ::v-global(.foo) -> .foo
if (n.value === '::v-global') {
if (value === ':global' || n.value === '::v-global') {
selectors.insertAfter(selector, n.nodes[0])
selectors.removeChild(selector)
return false
Expand Down

0 comments on commit f3cc41f

Please sign in to comment.