【发布时间】:2020-08-31 06:17:29
【问题描述】:
我想在一个 Vue 组件中访问项目中的 css 根变量的值。例如,更改 10 个变量,包括颜色、边距和字体大小,通过按一个按钮为新值,然后按相同的按钮将变量更改为它们的(默认)原始值,实际上是在更改值项目中的css根变量。我怎样才能做到这一点 ?其实我想通过按键来切换明暗。
这个想法的灵感来自以下链接中的更改。 链接里面的例子是用纯 JavaScript 脚本编写的,我想在 Next Js Framework 上开发的 Vue 项目中使用它。实现一个包含大约 10 个变量的网站,这些变量的值必须立即更改,只需按下按钮即可在暗/亮模式下切换。
The codepen link that inspired me :)
如何访问和更改 Css 根变量?
new Vue({
el: "#theme",
data: {
return {
dark: true,
};
},
watch: {
dark() {
let bg = this.dark ? "#1b1b1b" : "#f5f5f5";
let txtColor = this.dark ? "#999999" : "#333333";
document.documentElement.style.setProperty("--bg", bg);
document.documentElement.style.setProperty("--txt", txtColor);
}
}
});
:root{
--bg: white;
--txt: black;
}
body {
background-color: var(--bg);
color: var(--txt)
}
article {
padding: 50px
}
article h2 {
margin-top: 100px;
}
<div id="theme">
<button @click="dark=!dark">dark</button>
<article>
<h1>Hello World</h1>
Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor. Aenean massa. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec quam felis, ultricies nec, pellentesque eu, pretium quis, sem. Nulla consequat massa quis enim. Donec pede justo, fringilla vel, aliquet nec, vulputate eget, arcu. In enim justo, rhoncus ut, imperdiet a, venenatis vitae, justo. Nullam dictum felis eu pede mollis pretium. Integer tincidunt. Cras dapibus. Vivamus elementum semper nisi. Aenean v
</article>
</div>
【问题讨论】:
标签: javascript vue.js vue-component nuxt.js css-variables