layout | title | label | permalink | nav_order | parent |
---|---|---|---|---|---|
page |
Using Reactive CSS to Update Styles in Web-Components |
Reactive CSS |
/usage-web-components/reactive-css/ |
9 |
Usage |
CSS is much more fun when it's scoped. Here it come with the web-components.
Here again, no trick, just the full power of web-components and scoping styles. Well, you should know that the css is reactive too! 😲
Writing CSS is as easy as
<template>
<h1>Bonjour!</h1>
</template>
<script>
export default class extends Lego {
init() {
this.state = { fontScale: 1 }
}
}
</script>
<style>
:host {
font-size: ${state.fontScale}rem;
}
h1 {
padding: 1rem;
text-align: center;
}
</style>
:host
is a native selector
for web-components.
It allows to select the current component itself.
You can use variables in your CSS just like in your templates.
Example:
<template>
<h1>Bonjour<h1>
</template>
<script>
export default class extends Lego {
init() {
this.state = { color: '#357' }
}
}
</script>
<style>
h1 {
color: ${ state.color };
}
</style>
will apply the #357
color onto h1
.