- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我目前正在与 Puppeteer 合作.我注意到在 Chrome 开发工具中,我可以从任何元素(复制/复制选择器)中获取选择器,我想知道是否也可以从 Puppeteer 中的 ElementHandle 获取完整的 css 选择器。
例如,给定以下 html:
<body>
<h1>Main Title</h1>
</body>
const myElement=await page.$("h1");
body > h1
) 的完整 css 选择器
最佳答案
使用a userscript of mine的这部分:
var xpathNamespaceResolver = {
svg: 'http://www.w3.org/2000/svg',
mathml: 'http://www.w3.org/1998/Math/MathML'
};
getElementByXPath = function getElementByXPath(expression) {
var a = document.evaluate(expression, document.body, xpathNamespaceResolver, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);
if (a.snapshotLength > 0) {
return a.snapshotItem(0);
}
};
retrieveCssOrXpathSelectorFromTextOrNode = function(arg, type) {
var root = [], node;
nodeType = type.toLowerCase();
function retrieveNodeNameAndAttributes(node) {
var output = '';
try {
var nodeName = node.nodeName.toLowerCase();
} catch(e) {
console.error('ERROR no matching node');
return;
}
if (node.hasAttributes()) {
var attrs = node.attributes;
for (var i = 0; i < attrs.length; i++) {
if (nodeType === 'xpath') {
if (attrs[i].value) {
output += '[@' + attrs[i].name + "='" + attrs[i].value + "']";
}
else {
output += '[@' + attrs[i].name + ']';
}
}
else if (nodeType === 'css') {
if (attrs[i].value) {
if (attrs[i].name === 'id') {
if (/:/.test(attrs[i].value)) {
output += "[id='" + attrs[i].value + "']"; // new Ex: [id="foo:bar"]
}
else {
output += "#" + attrs[i].value;
}
} else if (attrs[i].name === 'class') {
var classes = attrs[i].value.split(/\s+\b/).join('.');
output += '.' + classes;
} else {
output += "[" + attrs[i].name + "='" + attrs[i].value + "']";
}
}
else {
output += "[" + attrs[i].name + "]";
}
}
}
}
var txt = '';
if (nodeName === 'a' && nodeType === 'xpath') {
txt = "[text()='" + node.innerText + "']";
}
root.push({ 'name': nodeName, 'attrs': output, txt });
if (nodeName === 'body') return;
else retrieveNodeNameAndAttributes(node.parentNode); // recursive function
}
if (typeof arg === 'string') { // text from within the page
var selector = '//*[text()[contains(.,"' + arg + '")]]';
node = getElementByXPath(selector);
} else if (typeof arg === 'object') { // node argument, let's do some 'duck typing'
if (arg && arg.nodeType) {
node = arg;
}
else {
console.error("ERROR expected node, get object");
return;
}
} else {
console.error("ERROR expected node or string argumument");
return;
}
retrieveNodeNameAndAttributes(node);
var output = '';
if (nodeType === 'css') {
output = root.reverse().map(elt => elt.name + elt.attrs ).join(' > ');
}
else if (nodeType === 'xpath') {
output = '//' + root.reverse().map(elt => elt.name + elt.txt + elt.attrs ).join('/');
}
else {
console.error('ERROR unknown type ' + type);
}
return output;
//console.log(output);
};
x = function(arg) {
console.log("CSS\n" + retrieveCssOrXpathSelectorFromTextOrNode(arg, 'css'));
console.log("XPath\n" + retrieveCssOrXpathSelectorFromTextOrNode(arg, 'xpath'));
};
console.log(x(node));
CSS
body.question-page.new-topbar[style] > div.container._full > div#content.snippet-hidden > div[itemscope][itemtype='http://schema.org/Question'] > div.inner-content.clearfix > div#mainbar[role='main'][aria-label='question and answers'] > div#answers > div#answer-49596712.answer[data-answerid='49596712'][itemscope][itemtype='http://schema.org/Answer'] > div.post-layout > div.answercell.post-layout--right > div.inline-editor[style] > form.inline-post[action='/posts/49596712/edit-submit/dbac2e78-20ec-4f98-86ee-60c3a57fb791'][method='post'][data-post-params='{"is_suggested_edit":false,"post_type":2,"owner":1,"PostId":49596712}'] > div#post-editor-49596712.post-editor.js-post-editor > div[style='position: relative;'] > div.wmd-container > textarea#wmd-input-49596712.wmd-input.processed[name='post-text'][cols='92'][rows='15'][tabindex='81'][data-min-length]
XPath
//body[@class='question-page new-topbar'][@style]/div[@class='container _full ']/div[@id='content'][@class='snippet-hidden']/div[@itemscope][@itemtype='http://schema.org/Question']/div[@class='inner-content clearfix']/div[@id='mainbar'][@role='main'][@aria-label='question and answers']/div[@id='answers']/div[@id='answer-49596712'][@class='answer'][@data-answerid='49596712'][@itemscope][@itemtype='http://schema.org/Answer']/div[@class='post-layout']/div[@class='answercell post-layout--right']/div[@class='inline-editor'][@style]/form[@class='inline-post'][@action='/posts/49596712/edit-submit/dbac2e78-20ec-4f98-86ee-60c3a57fb791'][@method='post'][@data-post-params='{"is_suggested_edit":false,"post_type":2,"owner":1,"PostId":49596712}']/div[@id='post-editor-49596712'][@class='post-editor js-post-editor']/div[@style='position: relative;']/div[@class='wmd-container']/textarea[@id='wmd-input-49596712'][@class='wmd-input processed'][@name='post-text'][@cols='92'][@rows='15'][@tabindex='81'][@data-min-length]
关于headless-browser - 从 puppeteer 的 ElementHandle 中获取选择器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49596638/
我最近刚跨过木偶继承。围绕它的几个问题: 使用p继承是一种好习惯吗?一些经验丰富的木偶同事告诉我,木偶的继承不是很好,我不太相信。 来自OO世界,我真的很想了解木偶继承的原理,以及覆盖的原理。 最佳答
需要一个 puppet 特工联系一些不同 puppet 师。 原因:不同的组创建了不同且独立的 list 集。 可能的组及其任务 应用程序供应商:应用程序的配置 安全性:强化 运营:路由表、监控工具
您可以在 puppet 中制作子模块吗,例如... puppet_root - modules - module_1 - submodule - manifes
在执行类 mypackage 中的代码之前,我需要执行类 mysql,tomcat。在我的 site.pp 我有 node 'node1' { include mysql,mypackage,tomc
我试图从失败的请求和js错误中收集数据。 我正在使用以下网站:https://nitzani1.wixsite.com/marketing-automation/3rd-page 该网站有一个对htt
我在 Suse 11 Linux 机器上使用 puppet 2.7.19 和 facter 1.6.0。 $::osfamily因子变量未设置,尽管它确实有 $::operatingsystem事实集
我正在使用 Puppet 开源版本。 我发现 Puppet 3.7.5 中有几个组件: puppet 大师 puppet 代理 MCollective 希拉 puppet 数据库 但我不知道他们是如何
主要目标是自动添加所有 puppet 模块,以便可以使用一个命令启动所有 dev-env 和 prod-env。如何通过 puppet manifest 安装 puppet 模块? 最佳答案 我们一直
我的 Puppet list 中有一系列 exec: 第一个下载带有二进制文件的 ZIP 文件(除非已经安装了二进制文件)并将其保存到 /tmp。 第二个将其解压缩。 当我第一次应用 list 时,它
我使用 aws opsworks 创建了 puppet master。我可以将 ami linux 节点自动添加到 puppet master。 当我尝试通过此链接 https://puppet.co
关于 this 的另一个问题问题。 有没有办法puppet module install从我已经下载到磁盘的本地存储库安装的工具? 最佳答案 您可以使用Puppet Library托管您自己的私有(p
我可以通过 Puppet Enterprise Master 到 Agent 运行几乎所有其他命令,但更新命令不会运行。据我所知,PE确实以root身份运行。 有人可以建议如何让这个命令在 Linux
我只想在 puppeteer 中刚刚打开的页面中应用标题,而不是在所有内部页面标题中应用标题 page.setExtraHTTPHeaders({ 'X-Just-Must-Be-Req
有没有什么方法可以用 Puppet 的语言声明数组中的包应该按照它们在数组中给出的顺序安装? 我想自动安装 CUDA,这需要 nvidia-driver-latest-dkms、cuda 和 cuda
鉴于这个简化的 Puppet 示例,很明显,由于 ~> 链接运算符,对 my_file 的任何更改都会触发 my_service 刷新: package { 'my_package': } -> fi
我是第一次使用 puppeteer,而不是工程师/程序员! 我已经能够生成我尝试使用 puppeteer 的大部分表单,但是我被单选按钮卡住了。网络表单中的开发人员工具显示该字段的以下内容: 使用:
如果您为代理在后台运行时执行 puppet agent -t,我们可以在其中看到更改的日志文件在哪里,而不是在 puppet 仪表板上。 我查看了 puppet.conf 并在主要部分看到了 logd
我正在尝试使用 exec 资源类型来执行批处理文件。但我想将变量 $dsn_64bit 的值从 init.pp 传递到 install.pp。请让我知道如何实现: 这是我的 init.pp class
我正在尝试使用 list 将用户分配到多个组,但遇到了障碍。 尝试 1: class usergroup { group { "user_one": ensure => present
我想先说我是 puppet 的新手。我一直在通过 vagrant 使用它并且我开始对写作表现感到自在,但我可能缺乏可以回答我的问题的经验或直觉。 我试图掌握 puppet 的范围以及画线的位置。我对这
我是一名优秀的程序员,十分优秀!