- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
需要完成:我需要模拟一系列网站之间的用户交互(旅程)。
问题:您对如何以编程方式控制因模拟点击而打开的选项卡有什么建议吗?
我的经验:我正在使用 chrome-remote-interface npm 包。我可以使用自定义 ChromeController 类来模拟点击,该类会初始化 chrome-remote-interface 和这些方法:
async simulateClick(selector) {
return await this.evaluate(function (selector) {
document.querySelector(selector).click()
}, selector);
}
/**
* Shamelessly stolen from simple-headless-browser
*/
async evaluate (fn, ...args) {
const exp = args && args.length > 0 ? `(${String(fn)}).apply(null, ${JSON.stringify(args)})` : `(${String(fn)}).apply(null)`
const result = await this.client.Runtime.evaluate({
expression: exp,
returnByValue: true
})
return result
}
现在我想与最近打开的选项卡进行交互。我可以使用实验目标域获取新选项卡的 targetId(在 Node cli 中进行原型(prototype)设计):
var targets;
chromeController.client.Target.getTargets().then(t => targets = t);
结果是:
{ targetInfos:
[ { targetId: '97556479-cdb6-415c-97a1-6efa4e00b281',
type: 'page',
title: 'xxx/preview/239402/',
url: 'xxx/preview/239402/' },
{ targetId: 'bbfe11d5-8e4a-4879-9081-10bb7234209c',
type: 'page',
title: 'Document',
url: 'xxx/preview/239402/teaser/0/' } ] }
我可以通过以下方式在选项卡之间切换:
chromeController.client.Target.activateTarget({targetId:'xxx'})
但是我无法与之进行任何交互,我找不到连接,也找不到如何将其加载到页面和运行时对象中。
我在文档中进行了搜索,还尝试了谷歌搜索:'site:chromedevtools.github.io targetId',这只会导致我
> chromeController.client.Browser.getWindowForTarget({targetId: '97556479-cdb6-415c-97a1-6efa4e00b281'}).catch(e => console.log(e.message));
Promise { <pending> }
> 'Browser.getWindowForTarget' wasn't found
我还尝试过 Target.setDiscoverTargets({discover: true}) 并关闭原始选项卡。
感谢您的帮助!
最佳答案
最近遇到了同样的问题,简而言之,我必须为我想要控制的每个新目标创建一个新的开发工具协议(protocol)客户端。
我的经验是使用与 websocket 直接通信的开发工具协议(protocol),但 api 是相同的,所以它应该是相似的。所以这里是我必须做的事情的总结。
最初查看文档时我会假设 Target.attachToTarget
应该让我们能够控制新选项卡,但我发现它不起作用。
我的解决方法是创建一个监听器来监听 Target.targetCreated
提供 targetInfos 的事件,就像您在 Target.getTargets
中找到的那样但对于创建的每个新目标,例如新选项卡、页面或 iframe。注意:您需要启用Target.setDiscoverTargets
为了通过协议(protocol)接收这些事件。
[ { targetId: '97556479-cdb6-415c-97a1-6efa4e00b281',
type: 'page',
title: 'xxx/preview/239402/',
url: 'xxx/preview/239402/' },
{ targetId: 'bbfe11d5-8e4a-4879-9081-10bb7234209c',
type: 'page',
title: 'Document',
url: 'xxx/preview/239402/teaser/0/' } ] }
通过该监听器,我查找页面类型的目标,如果您知道页面是什么,则可以过滤特定的 url。有了 targetId
,我在 devtools home page 底部附近的 HTTPEndpoints 部分之后请求了可用的 websocket 目标。 .
GET /json or /json/list
A list of all available websocket targets.
[ {
"description": "",
"devtoolsFrontendUrl": "/devtools/inspector.html?ws=localhost:9222/devtools/page/DAB7FB6187B554E10B0BD18821265734",
"id": "DAB7FB6187B554E10B0BD18821265734",
"title": "Yahoo",
"type": "page",
"url": "https://www.yahoo.com/",
"webSocketDebuggerUrl": "ws://localhost:9222/devtools/page/DAB7FB6187B554E10B0BD18821265734"
} ]
然后,我可以使用 webSocketDebuggerUrl 启动新的开发工具协议(protocol)客户端,并完全控制该选项卡。
我知道这是一种相当迂回的方式,但是,这是我能够实现的唯一方式。
尽管现在,如果可以的话,使用 puppeteer 之类的东西与 Chrome 中的多个选项卡进行交互可能会更容易。以下是 puppeteer 模块的源代码,该模块遵循新选项卡,可以作为尝试复制它的良好引用 pageVideoStreamCollector.ts
这是一个很晚的答案,但如果其他人遇到与 chrome 开发工具帮助相同的问题,那么将其放在这里是很难得到的。希望它能帮助别人。
关于node.js - Chrome开发者工具协议(protocol): control new tabs,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45637320/
我知道它们是匿名类型,但我不明白 Razor 语法。在一些文档中,我找到了这样的示例: @Html.Label("Hello", new { htmlAtributes = new { id = "h
关于:new Object(new Array()) 有一个相当基本的问题,我自己确实无法给出答案,我正在寻求建议: 在js中实例化对象时使用如下方法: var obj = new Object();
在eclipse中右击项目时,“新建文件夹”、“新建源文件夹”和“新建包”有什么区别?他们似乎都在做同样的事情,引用文献并没有说太多。 谢谢 最佳答案 新建文件夹 在项目中创建一个新文件夹。 新建源文
几天来我一直在测试 bolt-cms,我试图了解它是如何工作的。 我想知道新页面、新条目和新展示柜之间有什么区别。 我已阅读 this它并没有填补空白。 最佳答案 Pages、Entries 和 Sh
更新:感谢所有的回答。我发现的最干净的解决方案是这个: if ( k(Arrays.asList(new LinkedList<>())); 我有一个递归方法,可以从列表中生成所有“n 选 k”组合。
我现在想知道这些指令是如何分配内存的。 例如,如果我得到代码怎么办: x = new int[5]; y = new int[5]; 如果分配了这些,它在 RAM 中的实际情况如何?是为每个变量保留整
我希望将其写入output.txt而不清除它 - 只是附加到末尾。但是,当我使用以下两种方法时: public void addEmails(ArrayList emails){ for (i
我正在分配内存,稍后将用于构造具有放置 new 的对象。我应该使用 operator new(n),还是应该使用 new unsigned char[n]?为什么? 最佳答案 因素: new[] 必须
基本上,我的问题是以下代码是否有效。 void* mem = operator new(sizeof(T)); T* instance = new(mem) T; delete instance; 如
很抱歉,如果之前有人问过这个问题,但我想就以下两种用法之间的区别提供一个简明的答案。 VS 似乎将它们都接受为有效代码。 private static void doSomeWork() { /
请告诉我这段代码在做什么,它是否创建多维数组(我认为不是)? 代码片段.. var hanoi_peg = new Array( new Array( 5, 4, 3, 2, 1,
这个问题在这里已经有了答案: String intern() behaviour (4 个答案) When should we use intern method of String on Stri
许多人说您应该避免使用 new Object、new Array(),而是使用 {}。 [] 和真/假。 使用字面量构造来获取对象或数组的新实例而不是使用 new 有什么好处?我知道 Crockfor
我正在开发一个存在内存泄漏的开源库。该库是围绕 boost::asio 构建的数据流服务。服务器端使用堆内存管理系统,该系统提供内存以容纳有限数量的 samples,同时它们等待通过 tcp 连接被推
我从以下函数中得到内存泄漏: int ReadWrite(int socket, char *readfile) { FILE *rf = NULL; rf = fopen(readfile,
在考虑类似的事情时 auto x = new T; 标准是否强制要求内存必须来自operator new——类特定的还是全局的?也就是说,如果缺少特定于类的 operator new,则没有办法从除全
只是出于好奇:为什么 C++ 选择 a = new A 而不是 a = A.new 作为实例化对象的方式?后者不是更像是面向对象的吗? 最佳答案 Just out of curiosity: Why
考虑以下代码: typedef SomeType type_t[2]; SomeType * arr1 = new type_t; //new or new[] ??? type_t * arr2
这个问题在这里已经有了答案: Difference between 'new operator' and 'operator new'? (8 个答案) 关闭 8 年前。 面试题:"new"运算符和
我正在为一个应用程序设计界面,以在 TableLayout 中显示从数据库中提取的一些数据。现在,默认 View 是纵向的,它由一个下拉菜单和一个三列的表格组成。当用户切换到横向时,微调器及其选项可以
我是一名优秀的程序员,十分优秀!