- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在我的元素中,我使用了 CSS Modules with Less,这意味着我可以两全其美。
我的 src
文件夹看起来像这样:
components/
[all components]
theme/
themes/
lightTheme.less
darkTheme.less
palette.less
调色板.less:
@import './themes/lightTheme.less';
然后,在每个想要使用主题颜色的组件中,我这样做:
component.module.less:
@import '../../theme/palette.less';
.element {
background-color: @primary;
}
此结构允许我编辑 palette.less
以导入我想要使用的主题。问题是我想让用户自己选择他们喜欢的主题。主题应该可以在运行时切换,这意味着我需要以某种方式编译两个主题。
我想象完美的解决方案是这样的:
app.less
body {
@theme: @light-theme;
&.dark-theme {
@theme: @dark-theme;
}
}
然后以某种方式在每个组件中导入这个 @theme
变量并从中读取属性(即 @theme[primary]
)。
不幸的是,较少的变量作用域不能像这样工作。
<小时/>我对任何使用 Less 模块的解决方案持开放态度。
谢谢!
最佳答案
我知道您可能正在寻找使用 Less/CSS 模块的解决方案,但您的情况很可能只能通过使用 css 变量来解决(正如 Morpheus 对您的问题的评论)。
您必须确保所有样式不使用硬编码值,即:
.awesome-div {
background-color: #fefefe;
}
你会:
:root {
--awesome-color: #fefefe;
}
.awesome-div {
background-color: var(--awesome-color);
}
此方法中有两种更改主题的方法:
:root
CSS 元素,检查这个 codepen了解更多信息;:root
其 component.css 文件中的变量;在 React 中(也在普通 CSS 中),你可以轻松地让多个组件/元素声明自己的 :root
在他们的 .css 文件中。
此外,任何新的 :root
将覆盖先前 :root
中的冲突值。例如,如果在文件 app.css 中我们有 :root { --color: red; }
并且,当加载另一个组件(例如组件 A)时,在 component_a.css 中我们覆盖了相同的变量,例如:root { --color: blue; }
我们的浏览器中渲染的将是组件 A 中的渲染。
按照这个逻辑,您可以拥有一个不执行任何操作和呈现任何内容的虚拟组件,但在此 component.js 文件中导入主题的 .css,例如:
import './light.css'; // suppose this is the light-theme dummy component
在应用中切换主题时,您只需从场景中删除虚拟组件并调用另一个即可。
我对 codepen 的经验还不够丰富,无法为您提供一个包含导入/模块的示例,但我希望上面的解释能让您了解我的意思。尽管如此,这里还是我想要演示的一个简短的伪代码:
loadTheme() {
if (this.state.theme === 'dark') return <LightTheme />;
if (this.state.theme === 'user-3232') return <UserTheme />;
return <DarkTheme />;
}
render() {
return (
<App>
{this.loadTheme()}
<OtherContent>
</App>
);
}
关于css - 在 React 中使用 Less + CSS 模块切换主题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59787623/
这个问题已经有答案了: Cannot create AlertDialog: AppCompat error (2 个回答) 已关闭 6 年前。 当我在列表项中调用警报对话框时,我的应用程序崩溃了。我
我在 Angular 应用程序中安装了 Material UI,现在我收到错误,没有导出的成员 Observable 错误, 我删除了节点模块并重新安装,问题仍然存在 ERROR in node_mo
我有一个架构,其中有两个独立的应用程序。原始来源是一个sql数据库。 App1 监听 CDC 表以跟踪对该数据库中表的更改、规范化和序列化这些更改。它获取这些序列化消息并将它们发送到 Kafka 主题
这个问题在这里已经有了答案: Material Design, AppCompat, and Backwards Compatibility (1 个回答) 关闭 6 年前。 我收到如下错误信息:
我喜欢新 Office 套件和 Visual Studio 上的窗口镶边: 当然,我仍在为 Windows 7 开发应用程序,但我想知道是否有一种快速且简单的方法(阅读:WPF 样式或 Windows
我正在使用 HoloEverywhere-1.6.8。 我有一个基于 Holo.Theme 的自定义主题。 ... 我遇到了下面的崩溃,但它只出现在以下设备上: Galaxy Tab 10.1 P
我正在尝试为 Angular 的 DevExtreme 小部件加载主题。我采用了不同的方法: 在 angular.json 中设置样式但不会产生任何影响: "projects": { "my-proj
我想定义一个 android 样式,它扩展了一个在不同的应用程序/包中定义的样式,而不是作为库导入。 从对android资源的xml引用的定义here : @[:]/ 似乎可以在定义资源的地方指定一个
我正在尝试测试一种制作主题的方法,但我使用的方法并没有给我预期的结果。这是我的设置: drawable/dummy.xml 值/mythemes.xml @style
通过 telnet 使用 IMAP,我希望能够从特定的给定电子邮件中提取主题。现在我知道 fetch 命令负责从电子邮件中获取数据。 我的问题是,如何在不使用对 BODY[HEADER.FIELDS
我刚刚开始使用 RStudio 中的一些新的 knitr 功能。 我已经尝试在 R Markdown 设置对话框中选择几个不同的主题,但这些似乎对我生成的文档的样式没有任何明显的影响。应该,还是我错过
在我的应用程序中,我有多种主题样式(您可以将它们视为不同的、单独的 CSS 样式文件)。我想开始使用 CSS 模块,但我什至不知道如何 import我的第一个文件。 让我们假设以下(简单)目录结构:
有没有一种方法可以在一个 Azure 主题订阅上拥有多个监听客户端,并且它们都接收所有消息?我的理解是订阅的唯一实现是发布的消息仅传递到该订阅上的一个客户端,因为它就像一个队列。 可以使用同一订阅将这
我有一台 super 光滑的显示器,所以白天我可以比深色主题上的代码更好地看到自己的倒影。因此,我认为如果我可以在 vimrc 中有一个简单的 if 开关来根据一天中的时间设置深色主题或浅色主题,那就
我希望在我的 Symfony2 项目中提供基本的主题支持,因此我希望为每个主题提供单独的静态文件(css、js、img)。 我尝试添加 assetic: read_from: %kernel
有没有一种方法可以在一个 Azure 主题订阅上拥有多个监听客户端,并且它们都接收所有消息?我的理解是订阅的唯一实现是发布的消息仅传递到该订阅上的一个客户端,因为它就像一个队列。 可以使用同一订阅将这
在 NES 上有多个处于 WAITING 状态的“Discovery Worker”和“Keep Alive”线程是预期的行为吗? "DiscoveryWorker-10" Id=62 WAITING
我正在尝试找到最适合加载图像的颜色并将其应用到背景中。适应图像并使 UI 感觉更自然。 到目前为止我已经找到了 2 个方案: 1> 平均像素(下面的代码): final Color acclimati
我知道每个请求都由一个 servlet 线程提供服务,但是对于一个用户 session ,两个请求是否可以由两个不同的线程提供服务? 如果上述情况真的发生,那么第一个请求服务线程存储的线程局部变量被第
我无法理解操作栏外观与主题化之间的交互模式。我的应用设置为使用默认主题,我认为它是深色的: 通过应用范围内的样式从应用中删除操作栏会导致主要 Activity 的黑色背景: 没有 and
我是一名优秀的程序员,十分优秀!