- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在创建一个应用程序,我需要在其中管理利用影子 dom 的元素集合。由于模板标签封装了内容,我可以将样式和脚本与元素保持在一起,以便它们对事件起作用。我想知道的是,shadowRoot 中的脚本是否可以观察主机属性的变化。
我建议的路径是将数据属性附加到主机,让影子脚本监听对其的更改,然后更新 shadowRoot 内的元素。我知道可以使用 javascript 访问 shadowRoot 中的元素并更改它们,但我的愿望是尝试模块化和可重用性。我最终希望这个组件可以重用并对主机属性的变化使用react。
最佳答案
我找到了一个解决方案并认为我会分享。它可能还不兼容所有浏览器,但这就是生活。
在我的脚本中,我有一个 iffe/monad 来处理我的自定义 html 标签,创建影子根和模板的克隆作为内容。 monad 的参数之一是与我的自定义标记匹配的节点数组。在遍历它们时,我创建了一个 MutationObserver 来监视特定属性的变化,以便在闭包中使用创建的影子根。
(function (tags, template) {
Array.prototype.forEach.call(hexagons, function (v, k) {
var shadow = v.createShadowRoot();
shadow.appendChild(template.content.cloneNode(true));
/* mutation observer */
var observer = new MutationObserver(function (mutations) {
mutations.forEach(function (mutation) {
shadow.querySelector('.seconds')
.innerText(
mutation.target.getAttribute(mutation.attributeName)
)
});
});
observer.observe(v, { attributes: true, attributeFilter: ['bgcolor'] });
}
);
}(document.querySelectorAll('time'), document.querySelector('template#time')));
以上内容适用于最新的 Chrome 和 Firefox。我会继续寻找对浏览器更友好的解决方案。
关于javascript - 用于监视主机更改的影子 dom 脚本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24856031/
我正在尝试创建一个邻接列表,为此我需要创建一个链接列表的数组列表。当我这样做时,这个 cityList 的大小不会更改为构造函数中传递的大小。我觉得这可能是由于阴影造成的,但我不确定阴影是如何工作的,
我正在包装应用程序的影子 jar 。该应用程序使用kotlin和一些外部依赖项。所有依赖项都在我的jar中,但在运行时出现以下异常: java.lang.NoSuchMethodError: java
我有两个自定义元素 #shadow-root (open) 我正在尝试设计 像这样: #desktop::shadow desktop-window { backgro
通过此实例化的 Web 组件样式不正确: connectedCallback() { const shadowRoot = this.attachShadow({ mode: 'open' });
规范在这里 - https://drafts.csswg.org/css-scoping/#slots-in-shadow-tree有注释如下。 Note: A non-obvious result
我在我的应用程序中使用网络组件。在 Web 组件中,我需要插入一个 React 组件。 Web Component 有 Shadow DOM。当我尝试使用以下方法渲染 react 组件时,出现错误。
CSS Scoping说 The descendants of a shadow host must not generate boxes in the formatting tree. Instea
在尝试比较两个 dll 的 API 更改时,一位同事注意到某些类有两个 GetType() 方法。 经过更深入的检查,结果是 System.Exception 隐藏了 GetType(): // th
HTML代码: #shadow-root (user-agent) "this is text in textarea" 我正在尝试使用此 JQuery 使用 id="in
我正在使用 Robolectric 并尝试创建 GoogleApiClient 的 Shadow 对象,但没有成功。 Shadow 类中的方法永远不会被调用。 GoogleApiClient 是接口(
我正在尝试寻找一种不使用 iframe 来封装 Javascript 的方法。理想情况下,我想要一种在父页面上加载外部 HTML 组件(小部件)的方法,而无需使用 iframe 附带的两步加载过程(首
我是Gradle和Shadow jar(Gradle version of Maven's Shade plugin)的新手。我正在构建一个胖jar,我想在其中合并服务文件(这就是为什么我首先使用影子
如您所见,我想动态添加内容,但 shadow DOM 不显示内容 我怎样才能使内容可见?我想让内容可见。 let shadow = document.querySelector('#nameTag')
我正在编写一个 chrome 扩展程序,它可以在页面加载或更改时修改元素属性。 我使用 Mutation Observer 执行此操作。然而,当加载/更改 shadow-dom(即嵌入的 twitte
我试图了解单选按钮如何在影子 dom 中工作。我有一个脚本标签,我将一个影子 DOM 附加到一个元素,然后附加一些单选按钮。我的问题是单选按钮未呈现。 Title Radi
我读了很多关于 shadow DOM 的文章,但对此不是很清楚。能谁能告诉我什么是 shadow DOM 以及如何为下面的代码添加一个? 最佳答案 Shadow DOM
关于 的 CSS 优先级规则是怎么说的?影子 DOM 中的标签? 我有一个元素 , 中包含的 CSS 文件与: component { display: inline-block; }
如果我的 Web 组件是 的直接子组件,我必须对它应用特殊的 CSS 样式。元素。到目前为止,这是我尝试过的: /* applies even if the component isn't a di
我尝试使用 https://github.com/webcomponents/webcomponentsjs 中的 polyfill 制作我自己的 Web 组件 这是我的代码: im-list.htm
我是一名优秀的程序员,十分优秀!