- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在构建一个将直接嵌入第三方网站的 React 小部件。我想完全重置应用于我的小部件容器的 CSS <div>
,这样它就不会受到主机站点的 CSS(包括 !important
)的影响。元素使用React、Webpack,CSS modules , 和一些 PostCSS 插件。
我的 CSS 模块设置确实创建了唯一的私有(private) CSS 名称,这些名称不应与主机站点的 CSS 冲突。但是,这并不能防止主机站点 CSS,例如只需选择所有 button
为了解决这个问题,我一直在使用 Cleanslate作为重置样式表,它使用所有 !important
规则。这成功地阻止了应用来自主机站点的 CSS。但是,为了在 Cleanslate 上应用我自己的 CSS,我必须使用 !important
在我所有的 CSS 上,并增加我的 CSS 的特异性。我正在使用 PostCSS 插件来完成这两项工作。
不过,我也想在React中设置一些样式。我一直在为我的 DOM 元素添加内联样式(例如 style={{ color: "red" }}
)。但是,由于我要添加 !important
对于我所有的 CSS,这些内联样式总是被我的其他 CSS 覆盖。
除了 Cleanslate:
all: unset
,但遇到了与 Cleanslate 相同的问题——覆盖 !important
CSS,我必须使用 !important
在我所有的 CSS 中。styled-components
这样的 CSS-in-JS 解决方案,但是 styled-components
至少没有一种简单的方法可以始终应用 !important
(您可以使用 &&&
提高特异性,但这不会覆盖 !important
)。任何关于更改我当前的 CSS/JS 设置或可以实现此设置的其他设置的建议都将不胜感激。 (也许影响非常深远 !important
主机站点 CSS 只是边缘情况太小而无需担心。)谢谢!
TL;DR:第三方网站上的 React 小部件。我想覆盖主机站点的 CSS(包括 !important
),但也可以使用 JS 设置样式。
最佳答案
Shadow dom 之前的顶级技术是 <iframe>
,但在外部进行配置或做出一些智能行为是一件痛苦的事情。
看看 Shadow dom:https://developer.mozilla.org/en-US/docs/Web/Web_Components/Using_shadow_DOM
Shadow dom 是一个非常酷的普通功能,可让您创建 Web 组件。在幕后,Angular 也使用它。
曾经有一次,我自己做了一个小部件。并检查了所有选项,但最后,我发现最好的解决方案是 shadow dom,而 JivoChat 通过创建自己的元素(如 <jdiv>
)来做类似的事情。这将允许您安全地封装和设计您的小部件。
检查 JivoChat:https://www.jivochat.com/
关于javascript - 重置 `!important` CSS 并允许使用 JS 样式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68145970/
我刚刚通过更改 import * as CodeMirror 修复了一个错误简单明了import CodeMirror . 我复制了this code . (从 TypeScript 移植) impo
我调试(在 PyCharm 中)一个脚本。我在断点处停止,然后转到调试控制台窗口,然后从那里调用导入行,如下所示: import my_util1 from my_utils 然后我调用 my_uti
谁能给我解释一下 import 语句是如何工作的? 例如,我在 myapp/app/models 包中有一个类型 User: package models type User struct {
我想导入 Control.App进入一个引用 PrimIO.PrimIO 的模块通过不合格的名称 PrimIO在很多地方。当然,问题在于 Control.App还导出一个名为 PrimIO 的定义.我
我应该使用 from foo import bar 或者 import foo.bar as bar 当导入模块 还有无需/希望更改名称 (bar)? 有什么不同吗?有关系吗? 最佳答案 假设 bar
我正在 Windows 上使用 Theano 进行深度学习实验的第一步,我很惊讶仅仅加载库需要多少时间。 这是小测试程序: from time import time t0 = time() impo
在 TypeScript 中,如何在不创建任何别名的情况下从文件“导入 *”? 例如我有一个包含顶级导出函数的文件“utils”,我想导入所有这些函数而不为每个函数重新创建别名。 像这样: impor
我应该使用 from foo import bar 或 import foo.bar as bar 当导入模块并且不需要/希望更改名称(bar)? 有什么不同吗?有关系吗? 最佳答案 假设bar是fo
这个问题在这里已经有了答案: Use 'import module' or 'from module import'? (23 个回答) 关闭8年前。 我想知道代码片段之间是否有任何区别 from u
我试过了 from urllib import request mine = request.Request() 和 import urllib.request mine = urllib.reque
所以,我有一个关于 Python 导入的小谜团。我确信出于某种原因事情应该是这样的,因为 Guido 很少出错。但是,为什么会这样呢? $ cat myModule.py #!/usr/bin/pyt
我们正在将 Rails 3.2 应用程序升级到 Rails 4.0。 我们有一个 assets/stylesheets/application/index.css.sass加载一些其他 sass 文件
我正在开发一个相当小的 Typescript 代码库,该代码库已经足够大,可以拆分到多个文件中。这是一个二十一点游戏。我目前有一堆代码,看起来像: var player = new Player();
是否可以以当模块为 use 时的方式编写模块? d 没有显式导入所有子例程都被导入,当它是 use d 显式导入只有这些显式导入的子程序可用? #!/usr/bin/env perl6 use v6;
这个问题在这里已经有了答案: how to watch changes in whole directory/folder containing many sass files (9 个回答) 5年前
我真的很难让它在 xcode 4 中工作。 我有一个项目将在许多应用程序(网络)中重用,因此我创建一个工作区并添加我的两个项目。到目前为止,一切都很好....这就是失败的地方.. #import "J
经典提取器和新提取器之间的主要区别是什么,哪个最好用? 最佳答案 经典提取器使用原始工作流程,与爬虫和连接器相同。 新的提取器更加精简,通常看起来和感觉都更好,并且经典提取器中的许多小错误已在新提取器
在处理 google webfont import mixin 时,我注意到无法动态构建 @import URL。 .gFontImport (@name, @weights, @subsets) {
我正在关注Django 1.8 tutorial 。在我的项目中mysite ,有一个源文件夹polls 。文件夹中有views.py模块其中 index函数已定义。还有一个urls.py文件: fr
我想使用名为 warp 的第三方库编译一个简单的 Rust 程序: [package] name = "hello-world-warp" version = "0.1.0" [dependencie
我是一名优秀的程序员,十分优秀!