- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
在使用 polymer 元素时,我发现他们的 Shadow DOM polyfill 页面有一组已知的限制 http://www.polymer-project.org/platform/shadow-dom.html#known-limitations .
列表中的第一个限制是:
在我运行的一些简单测试中,我没有发现任何封装问题。我有一个 jsbin,我一直在测试东西。 http://jsbin.com/ANeCUv/10/edit .
为了测试,我从 polymer 模板内的样式标签中删除了 css import 语句。我注意到即使在上述 header 的样式标记中仍然调用了相同的导入,该元素也变得没有样式。这至少在这种情况下向我展示了封装阻止了 jquery-ui.css 为我的元素的 Shadow DOM 设置样式。
我决定更具体地研究这个问题,并找到了一些引用资料,例如样式指南评论中的这个 http://www.polymer-project.org/articles/styling-elements.html
我再次使用旧版本的 IE 进行了测试,并确认 css 从元素外部引用的样式中渗入。
我理解 polymer 及其 polyfill 的设计,是为了让更新的网络技术易于访问,并允许旧浏览器中不支持的功能得到旧技术或优雅故障转移的支持。所以我理解这个问题将如何被视为 Shadow DOM polyfill 的限制。
除了这个支持旧版浏览器的问题,我没能找到其他封装问题。如果唯一已知的特定限制是与旧浏览器不兼容,那么“CSS 封装是有限的”是一个非常通用的标签。
除了旧版浏览器中 Shadow DOM polyfill 支持的不一致之外,还有其他已知的 CSS 封装问题吗?
最佳答案
大多数时候,您永远不会遇到问题,或者只需要进行一些调整即可在 polyfill 和原生 Shadow DOM 下工作。
这个 bin 说明了两个常见问题:http://jsbin.com/hugoliyo/2/edit
如果您在 Chrome 稳定版与 FF、Safari 或 IE 中运行该页面,您会看到不同之处。
第一个限制是来自主页的样式可能会泄漏到 polyfill 的影子 dom 中。这是第一个示例,其中元素的影子 dom 中的 div 被设置为红色。那是因为没有阻止外部样式匹配的影子 dom 边界。
第二个限制是插入点。 polyfill 重写了原生选择器 ::content p
成为my-element p
,这反过来又错误地匹配了 <p>
在影子 dom 中。
这两个问题都有变通方法,但需要小心处理。 http://www.polymer-project.org/docs/polymer/styling.html谈论如何强制执行严格的样式和使用 polyfill-*
选择器在 polyfill 下进行调整。
希望这对您有所帮助。
关于javascript - Polymer 及其 Shadow DOM 中的 CSS 封装限制,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24806213/
我无法创建另一个父 div 容器,是否可能仅使用 css 技巧?盒子阴影:7px 7px 7px 黑色;只会从右边框和底边框创建阴影,但我也需要左边框和上边框。 最佳答案 盒子阴影有4个参数;偏移量、
我刚遇到一个有趣的情况,我有一个提交 放置在 内的 native 自定义元素的 Shadow DOM 内. Select #shadow-root ...
假设我们有一些 CSS 代码,例如动画 CSS 加载器,我们希望在所有使用 Shadow DOM 的 Web 组件中使用它。如果我们无法像 ::shadow 那样穿透 Shadow DOM,我们如何重
shadow-dom 中的document 变量的值是多少?在 this jsfiddle 我们可以看到它在父文档中搜索 app 节点并提醒它的值。这是否意味着 shadow-dom 没有单独的文档变
以下代码是来自 chrome 开发工具的 View #shadow-root (user-agent) This I want to restyle 如果我想在 shadow
运行mvn package:shade shade时,日志中的条目显示:用 XYZ-shaded.jar 替换 XYZ.jar但在我的目标目录中,我找不到阴影 jar 这是我关于 Maven 阴影的
我正在尝试编写一个 mixin,它应该将 CSS box-shadow 作为参数并将其转换为 filter: drop-shadow()。 // mixin drop-shadow($shadows)
我正在使用 gradle shadow 插件构建我的 uber jar。 build.grade 文件看起来像: buildscript { repositories { jc
我正在尝试向子对象所在的父对象添加阴影 元素位于其中。我希望插入的阴影与图像重叠。 我的 HTML 代码是: 和 CSS: .highlights { height: 360px
我想在 UIView 上添加drop shadow 和stroke shadow这是我的设计师给我的阴影, 对于投影,他告诉我使用 RGB(176,199,226),不透明度为 90%,距离为 3,大
我希望在单击图像时出现投影。我目前不使用 Jquery,所以如果可能的话,请提供一个 java 脚本解决方案。这是我的 fiddle :http://jsfiddle.net/zUNhD/7/ 我还希
从那以后我一直在使用 CSS box-shadows,但现在我有一个带有圆 Angular 的图像并想给它一个圆 Angular 阴影。所以我尝试使用 filter: drop-shadow,但不幸的
LWC 合成影子 dom 似乎不像 native 影子 dom 实现那样处理插槽,例如 假设您从一个元素开始: Hi there 然后附加影子dom并添加一个插槽,h1将被插入: 现在,如果您在运行“
我试图在以下文档中观察文档级别的自定义输入元素的文本输入元素的输入值的变化: 其中自定义 Div 和自定义输入定义如下: Units 如状态h
我的网站上安装了一个 Angular 网络组件。它使用 Shadow DOM,因此它非常快(在我的情况下必须如此)。 在我的站点上,我还有一个快捷方式 h,它会打开一个显示一些有用信息的弹出窗口。 h
我正在尝试为一个带有与其文本颜色相同的阴影的框创建样式。因为我有几个框,每个框都有不同的文本颜色,所以我想避免在每个框的每个单独规则集中重复相同的颜色。 现在,背景和边框模块状态为 box-shado
我想使用不支持 Shadow-DOM 的浏览器(如 Firefox、PhantomJS 以及其他使用 WebDriver 的浏览器)测试 Polymer 应用程序。 当我使用类似的东西时,Firefo
我有一个 Assets 代表一个按钮,下面有一个阴影。我只想让蓝色部分可点击。有没有简单的方法来做到这一点? 谢谢。 最佳答案 您可以像这样以编程方式添加阴影: button.layer.shadow
我正在尝试创建一个 Photoshop 内阴影效果,与 css3 框阴影插入效果相同。 第 1 步(我正在生成按钮 - 圆 Angular 矩形): convert -size 220x50 xc:n
我需要在 boxMesh 上转换阴影,而网格本身应该不可见。 我找到了 technique Three.js GitHub 问题跟踪器似乎在几年前就可以工作,但现在不再工作了 - 它涉及创建一个新的着
我是一名优秀的程序员,十分优秀!