- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我尝试截取 AMP Stories 的屏幕截图,但不使用声音和分享按钮。
当我发现有一个叫做shadow DOM的东西之后,我想知道如何在那里设置显示:无:
addStyleTag({content: '.i-amphtml-story-system-layer-buttons { display : none!important }'})
我想我是这样访问影子 DOM 的。
const shadowRootInnerHTML = await page.evaluate(() => {
return document.querySelector("body > amp-story > div").shadowRoot.innerHTML
});
这是我目前正在使用的,
const browser = await puppeteer.launch({
slowMo: 250,
args: [
'--disable-infobars',
]
});
const page = await browser.newPage()
await page.emulate({
name: 'iPhone1080x1920',
userAgent: 'Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/11.0 Mobile/15A372 Safari/604.1',
viewport: {
width: 360,
height: 640,
deviceScaleFactor: 3,
isLandscape: false
}
});
await page.goto(urlToTest, {
waitUntil: 'networkidle2',
timeout: 0
});
const textContent = await page.evaluate(() => {
return document.querySelector("body > amp-story > div").shadowRoot.innerHTML
});
最佳答案
Amp 页面在 amp-story 中有多个 div 元素。
我们可以执行这个普通的 JavaScript,它将隐藏放大器页面上的顶部幻灯片和共享按钮。
我在这段代码中添加了两种方法,您可以应用其中一种。
// there are multiple div elements inside amp-story
const elements = [...document.querySelectorAll("body > amp-story > div")];
elements.map(rootElement => {
// find the shadowRoot inside if it exists
const shadowRoot = rootElement.shadowRoot;
if (shadowRoot) {
/**
* WAY 1: Find the element and apply css to it directly
*/
// this holds the top share button and pagination slides
const element = shadowRoot.querySelector(
".i-amphtml-story-system-layer"
);
// forcefully hide the element
if (element) element.style.setProperty("display", "none", "important");
/**
* WAY 2: Append your own style to the <style> tag inside the amp shadowRoot
*/
shadowRoot.querySelector('style').innerHTML += `.i-amphtml-story-system-layer { display : none!important }`
}
});
基本上,
示例放大器页面上的结果:
关于javascript - 使用 Puppeteer 操作/设置 ShadowRoot 样式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56306165/
我正在尝试在 Javascript 中选择 Shadow 根,以便我可以设置内部元素的样式。但是当使用 elem.shadowRoot 时它返回 Null 尽管 ShadowRoot 是下一个元素。下
我的自定义 HTMLElements 中的大多数事件处理程序看起来像这样, totalChanged() { if (!this.shadowRoot) return const
我正在尝试克隆影子根,以便我可以交换 的实例及其相应的分布式节点。 我的方法: var shadowHost = document.createElement('div'); var shadowR
我试图在另一个自定义元素阴影根中访问我的自定义元素的内容。 index.html刚好有一个 my-tag-wrapper元素: ... ... my_tag_wrapper.html包含 my-t
我有一个丰富的编辑器,我正在将其重写为 lit-element 自定义元素。我正在使用 Firefox(最新)进行测试。我正在尝试在自定义元素的 shadowDom 中选择内容可编辑元素(在方法中)。
这个问题在这里已经有了答案: How to access host element from within the shadow root using Shadow DOM v1? (2 个答案)
我无法理解何时可以访问组件的 shadowRoot。这是一组嵌套组件的图像: 所以有一些组件: MortgageDetails:将一组 3 个其他组件绑定(bind)在一起的组件 MoneyInput
我在测试上下文中对 shadowroot 中的元素执行操作时遇到困难。假设我有一个 Web 组件 它包含一个按钮 从 chrome 控制台,我可以执行以下操作: document.getElement
所以我有这个角 Dart 组件: @Component(...) class TableCard implements AttachAware, ShadowRootAware { void on
我在访问 Polymer 元素的 shadowDom 时遇到问题。这是元素的(截断)代码: Drag and drop the letters to form anagrams
Chrome 中的谷歌翻译扩展,具有弹出功能,它会立即显示所选单词的翻译,我想访问弹出显示的那些翻译,但是这个弹出元素是 shadowRoot("closed"),所以 javascript 无法访问
在下面的示例中,我尝试创建一个菜单组件来试验组件层次结构。 index.html Sample Menu App
我正在尝试访问元素上的 ShadowRoot,属性 element.shadowRoot 返回 null。 ShadowDOM 定义为 mode: 'open',这是正确的,我什至可以通过 conso
我正在使用 Jest 设置 Vue3 和单元测试。 我已经不得不努力让它工作,并且我已经尝试了很多不同的配置。 这是我最后一次“工作”配置,我得到了这个错误: ReferenceError: Shad
我正在尝试使用以下内容读取元素的值 (innerHTML/innerText) 属性,但我得到一个空字符串。cy.get('#INGLoanRequests-container').shadow().
我正在尝试访问 ShadowRoot dom 树元素,但我面临的问题是我无法使用特定的 html 元素来调用 .ShadowRoot,因为该元素是动态的(请参见下面的 html 片段 id="vaad
我正在创建一个自定义元素并将其 shadowRoot 设置为包含其他自定义元素,这会引发 NotSupportedError (DOM Exception 9): A newly constructe
我尝试截取 AMP Stories 的屏幕截图,但不使用声音和分享按钮。 当我发现有一个叫做shadow DOM的东西之后,我想知道如何在那里设置显示:无: addStyleTag({content:
好的,所以我在这里看到了一些与我的问题类似的问题,但没有一个解决方案对我有用,所以我认为最好更具体地描述我的问题。 我正在使用 Web 组件,起初我没有使用 lit 元素,当时 this.shadow
我有一个非常简单的网站,类似于 jsfiddle .一切似乎都很好,但在我的本地,但是当我停在第一行 JS 时(在声明自定义元素之前)我可以看到没有格式的 div ...... T
我是一名优秀的程序员,十分优秀!