Reputation: 6981
So, I've read here that in Vue.js, you can use /deep/
or >>>
in a selector in order to create style rules that apply to elements inside of child components. However, attempting to use this in my styles, whether in SCSS or in plain old CSS, doesn't work. Instead, they are sent to the browser verbatim, and therefore have no effect. For example:
home.vue:
<style lang="css" scoped>
.autocomplete >>> .autocomplete-input
{
// ...
}
</style>
generated css:
<style type="text/css">
.autocomplete >>> .autocomplete-input[data-v-2bda0c9a]
{
//...
}
</style>
what I want:
<style type="text/css">
.autocomplete[data-v-2bda0c9a] .autocomplete-input
{
//...
}
</style>
My webpack configuration pertaining to vue-loader
looks like this:
// ...
{
test: /\.vue$/,
loader: "vue-loader",
options: {
loaders: {
scss: "vue-style-loader!css-loader!sass-loader"
}
}
}
// ...
So my question is, how do I get this >>>
operator to work?
I've already found this answer, but I'm doing exactly that and it doesn't work...
Upvotes: 199
Views: 246760
Reputation: 63059
In Vue 3, the ::v-
prefix is now deprecated and we no longer need >>>
. We can use the unified :deep
selector whether using Sass or not, but now it's recommended to use parentheses with the selector.
Use :deep(.child-class)
:deep(.child-class) {
background-color: #000;
}
This also works in Vue 2.7 (final Vue 2 release)
The following also works in Vue 3 but is deprecated.
Sass: Use ::v-deep
::v-deep .child-class {
background-color: #000;
}
Not using Sass: Use >>>
>>> .child-class {
background-color: #000;
}
With either syntax, the <style>
tag for this component must be scoped
:
<style scoped>
Additionally, in Vue 3, there is a new feature for components with a <slot>
that enables styling passed slot content.
Slot content Use :slotted(.child-class)
:slotted(.slot-class) {
background-color: #000;
}
And lastly, in Vue 3, there is a new feature to register global styles even from a scoped
component:
Global styles Use :global(.my-class)
:global(.my-class) {
background-color: #000;
}
With any syntax, the <style>
tag for this component must be scoped
:
<style scoped>
In Vue 2:
/deep/
syntax is deprecated::v-deep
with Sass, use >>>
without SassIn Vue 3:
::v-deep .child-class
is deprecated in favor of :deep(.child-class)
::v-
prefix is deprecated in favor of :
>>>
syntax is deprecated/deep/
syntax is deprecated:slotted
and :global
selectorsWith every version/syntax, the <style>
tag for this component must be scoped
:
<style scoped>
Upvotes: 471
Reputation: 131
Consider that you have this modal with a specific class 'approval modal' :
<v-dialog v-model="requestForApproveModal" class="approval-modal">
...
</v-dialog>
You can select child classes of this modal using this CSS code inside the scoped style block:
<style scoped>
.approval-modal:deep(.v-alert__content){
font-size: 18px;
}
</style>
Also note that in my example 'v-alert__content' that I am selecting with deep selector, is for vuetify alert component.
Upvotes: 0
Reputation: 575
To override the CSS properties of a specific element in Vue.js use Vuetify, below workded for me:
<style scoped>
::v-deep .v-overlay__content {
contain: none !important;
}
</style>
OR
<style scoped>
>>> .v-overlay__content {
contain: none !important;
}
</style>
Upvotes: 0
Reputation: 111
::v-deep usage as a combinator has been deprecated. Use :deep() instead.
:deep(.child-class) {
background-color: #000;
}
Upvotes: 11
Reputation: 379
I solved this problem by adding
options: { styleIsolation: 'shared' }, // add this
methods: {
yourFunc1 () {
}
}
.pet-info{
::v-deep .title {
width: 51px !important;
background-color: red !important
}
}
Config this in the components like the methods, it's the same level like methods.
Upvotes: 0
Reputation: 368
Though it is not found in the Documentation, the answer is that the component you are attempting to reach cannot be the root component. Wrap your single component in a <div>
and it should work using ::v-deep
on scoped scss
as others have explained.
Upvotes: 3
Reputation: 1047
For me, the only thing that worked was
<style scoped>. // sass and scss didn't work
>>> .deep-selector {
...
}
</style>
Upvotes: 3
Reputation: 6912
Avoid using /deep/
and instead use ::v-deep
Any scoped component's
css can be changed by using deep selector
but sooner /deep/
will get deprecated
Vue Github reference - https://github.com/vuejs/vue-loader/issues/913
Use ::v-deep
in this case,and avoid deprecated /deep/
Reference - Deep Selector
Just inspect class of the rendered element
which you want to modify using devtools
in chrome or any browser console.
Then, In you consuming component
, modify it
<style scoped>
::v-deep .custom-component-class {
background: red; //
}
</style>
Upvotes: 31
Reputation: 522
I've successfully used /deep/ in Vue's scoped SCSS stylesheets with this structure:
.parent-class {
& /deep/ .child-class {
background-color: #000;
}
}
Edit: /deep/ is being deprecated, if it no longer works for you please refer to the other answer that explains ::v-deep
Upvotes: 26