- 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/
我有一个“设置首选项”屏幕。它有一个 ListPreference 和一个 CheckBoxPreference。当我选择 ListPreference 的一项时,我想更改应用程序的日期格式。另外,通
我试图找到创 build 置/配置窗口的示例。单击菜单项中的“选项”操作可启动设置窗口。我想弄清楚如何从主窗口打开第二个窗口。以及新窗口如何将设置信息返回主窗口。尝试使用 QDialog 或一些继承的
我在 Lnux 上有 Qt 应用程序。我想为此创建一个可执行文件/设置以便在 Windows 上分发它并且不需要安装 Qt。我通过包含所有 dll 为此创建了可执行文件但要运行它,用户需要进入文件夹。
我正在尝试创建一个有点动态的 html 类,它根据类末尾包含的数字设置宽度 %。注意:类名将始终以“gallery-item-”开头 示例:div.gallery-item-20 = 20% 宽度 我
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 6 年前。 Improve this qu
在我的应用程序中,我想记住一些变量,例如,如果用户登录过一次,那么他们将在下次重新打开应用程序时登录,或者如果他们决定禁用某些提醒,应用程序可以检查该变量是否是错误的,将不再显示该提醒。理想情况下,这
我在 Netbeans 中开发了一个应用程序,它连接到远程计算机的消息队列并发送消息。该应用程序还有其他功能。项目完成后,我清理并构建应用程序,然后 Netbeans 创建一个 jar 文件。 但我的
我创建了一个 Outlook 加载项,需要创建一个设置以使其可分发(我是新手,所以请原谅新手评论) Outlook -2010 Vs -2010 .Net 4.0 我读了一些地方,最简单的方法就是发
这个问题已经有答案了: 已关闭10 年前。 Possible Duplicate: How to make installer pack of Java swing Application Proje
这个问题肯定已经被很多人解决过很多次了,但是经过几个小时的研究,我仍然没有找到我要找的东西。 我有一个 ExportSettings.settings 文件,其中包含一堆设置( bool 值、字符串、
我想为我的项目创建一个安装程序,以便它可以安装在任何电脑上而无需安装头文件。我怎样才能做到这一点? 最佳答案 一般有两种分发程序的方法: 源代码分发(要构建的源代码)。最常见的方法是使用 GNU au
如何在这样的动态壁纸中创 build 置 Activity ? Example Picture 我只用一个简单的文本构建了设置 Activity ,但遇到了一些问题。第一个问题是我不能为此 Activ
我用 GUI 创建了一个简单的软件。它有几个源文件。我可以在我的编辑器中运行该项目。我认为它已经为 1.0 版本做好了准备。但我不知道如何为我的软件创 build 置/安装程序。 源代码是python
我的 SettingsActivity当前扩展了 Android Studio 生成的类,AppCompatPreferenceActivity扩展 PreferenceActivity . Acti
我正在使用 .NET 为 IE 开发工具栏。目前,我使用 gacutil 插入我的 .NET 程序集,并使用 regasm 注册我的 COM 程序集。 我想为项目创建一个设置 (MSI),但我似乎无法
在为设置页面创建 Activity 后,我注意到 if (mCurrentValue !== value) 中的 mCurrentValue !== value 返回警告: Identity equa
我在 Visual Studio 10 中创建了一个项目,该项目使用 Mysql 数据库和 Crystalreports 以及 它。但是我不知道如何进行自动安装 Mysql 和 Crystalrepo
我正在尝试在我的 C# 项目中使用 Sqlite 数据库,并且我在 IDE 中做得很好。我的问题是当我为我的项目制作安装包并安装它时,程序无法访问 sqlite 数据库。我也知道这是因为用户没有访问文
我有一个大型 Web 应用程序(带有 11 子系统的 ErP),我想使用 Microsoft WebPI 为它创建一个设置。 目前,我们每周向客户发送一次应用程序(用于每周更新)。 我们在此应用程序中
所以我对工资单申请的最终查询是 - 如何为薪资申请创 build 置? 我需要知道的一切- 如何将设置项目添加到我现有的解决方案 如何将解决方案中的文件添加到安装项目中,以及添加哪些文件添加和在什么文
我是一名优秀的程序员,十分优秀!