-
-
Notifications
You must be signed in to change notification settings - Fork 8.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat(custom-element): inject child components styles to custom element shadow root #11517
Conversation
Size ReportBundles
Usages
|
for (let i = styles.length - 1; i >= 0; i--) { | ||
const s = document.createElement('style') | ||
s.textContent = styles[i] | ||
this.shadowRoot!.prepend(s) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@yyx990803 Can we do the append? As my global styles are in the last tag and override child styles. In case of append we would have child styles come after the global. Maybe an option to specify this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Any news on this? I'm trying to add my layers' order (@layer resets, plugins, application, components, overrides;
) as a first style child but it's impossible when importing style in children components who themselves have @layer
declaration as root element
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@Nicolas-Nmedia in my case I had to use scoped on the style tag in SFC as the order of how these style tags are prepended was overwriting some styles (I use tailwind). Maybe we could help contributing but not sure where to start familiarizing myself with the project.
Exactly our problem too... |
This is not a real solution to the issue imho. I might be worng. As far as I can see, this way it is not possible to use the same child-component within a shadow-root and within normal app scenario. Imagine a button you want to use on the one-hand on some shadow-root component and one the other hand within an app that was mounted on some none-shadow-root div on your page. |
yes. We're planning a component library which will have a copy and separate exports for CE and non CE. But this is far from ideal. |
close #4662
close #6610
close #7941
This references both #6610 and #7942 but implements it in a way that minimizes changes to
runtime-core
and also handles HMR for child-injected styles, without relying on changes to@vitejs/plugin-vue
.With this change, a
*.ce.vue
component can import other*.ce.vue
components and use them directly as Vue child components instead of custom elements. Child component's styles will be injected as native<style>
tags into the root custom element's shadow root: