- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在使用 CasperJS 开发一个网站抓取项目。这是一个 ASPX 网站。我可以登录该网站,然后填写运行搜索的表单,但填写表单后我无法模拟单击 DIV 按钮。搜索使用 AJAX 运行,但是当我在等待几秒钟后捕获页面时,它不会在捕获的图像中显示结果。 “搜索”按钮由 DIV 组成,单击它后会运行其他隐藏的 JavaScript 函数,这些函数发送 AJAX 请求以检索搜索结果。
这是我的代码。
var casper = require('casper').create({
clientScripts: ['js/jquery-1.11.3.min.js']
});
var x = require('casper').selectXPath;
casper.userAgent('Mozilla/5.0 (compatible; MSIE 8.0; Windows NT 6.1; Trident/4.0; GTB7.4; InfoPath.2; SV1; .NET CLR 3.3.69573; WOW64; en-US)');
casper.start('https://example.com/finder.aspx');
casper.then(function () {
this.sendKeys('#UserName', 'xxxxx');
this.sendKeys('#Password', 'yyyyy');
console.log('Fill login credentials');
casper.capture("screen1.png");
this.thenClick('input[type=submit]');
});
casper.wait(3000, function () {
console.log('Login');
casper.capture("screen2.png");
});
casper.then(function () {
this.fill('form[name="searchForm"]', {
'$ddType': 'ABCD',
'$rbGender': '0',
}, true);
});
casper.wait(3000, function () {
this.sendKeys('#Type_I', 'ABCD');
this.sendKeys('#ProviderId', '1111111111');
this.sendKeys('#txtNameFirst', 'My');
this.sendKeys('#txtNameLast', 'Name');
this.sendKeys('#txtZipCode', '11111');
this.sendKeys('#txtBirthDate', '01/11/1987');
console.log('Form filled');
casper.capture("screen3.png");
});
casper.thenClick('#btnSubmit', function () {
console.log('Submitted');
});
casper.wait(3000, function () {
casper.capture("screen4.png");
});
这是需要单击的按钮 DIV。
<div id="btnSubmit" class="dxb">
<span>Submit</span>
</div>
screen4.png(与 screen3.png 相同)仅显示填充的搜索表单,但没有“正在加载..”消息(应该在单击提交时显示)或任何结果。如何触发表单提交?普通表单提交不会检索搜索结果。
<小时/>PS:我尝试了以下方法来触发evaluate()
内的提交按钮。
在文本框中输入 press (实际上显示结果)
var e = jQuery.Event("keydown");
e.which = 13;
$("#txtZipCode").trigger(e);
this.sendKeys('#txtZipCode', casper.page.event.key.Enter, {keepFocus: true});
单击 DIV 按钮。
$('#btnSubmit div input').trigger('click');
$('#btnSubmit').click();
var mouse = require("mouse").create(casper);
this.mouse.click("#btnSubmit");
还是没有运气。
最佳答案
casper.then( 函数 () {
this.clickLabel('提交', 'span');
});
我遇到了类似的问题,这对我有用。
关于javascript - CasperJS 无法点击 DIV 按钮,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31697141/
运行测试时获取。 FAIL 35 tests executed in 16.806s, 35 passed, 0 failed, 2 dubious, 0 skipped. “可疑”意味着什么?如何查
是否有人已经使用 casperjs 实现了著名的“页面对象模式”,从长远来看,它对于测试的可维护性非常有用? 当您必须将测试的机制和目的分开时,使用它非常非常酷。以这种方式编写测试会变得更加愉快。 有
所以,我试图在我的服务器上运行 casperJS 作为 cron 作业,这是 crontab: * * * * * /usr/local/bin/casperjs /var/www/javascrip
我知道如何禁用图像和插件,但似乎没有明显的选项来禁用 CasperJS 中的 css。 有谁知道这是如何工作的? 最佳答案 假设您想抑制所有外部样式表的加载,您可以通过中止加载 css 文件的请求来实
我在删除网站时从创建的 URL 下载文件时遇到问题。目前我发现了一个文件的月份和年份,然后替换了 url 中的值并尝试从该位置下载。我了解到您无法使用评估范围内的下载功能。 this.evaluate
在 CasperJS 中,如何在使用 casper.thenOpen() 时保持 session 例如: var casper = require('casper').create(); casper
我希望我的 casper 在 session 期间登录并保持登录状态。有可能吗?如果是这样,如何? 最佳答案 如果你想在 CasperJS 中存储 cookie,你可以使用 PhantomJS coo
我用 casperjs 编写了一些测试。他们与 phantomjs 一起运行得很好。但是,当我尝试通过以下命令使用 slimerjs 时: casperjs --verbose --engine=sl
我用 casperjs 编写了一些测试。他们与 phantomjs 一起运行得很好。但是,当我尝试通过以下命令使用 slimerjs 时: casperjs --verbose --engine=sl
我想单击“提交”按钮,等待下一页加载,然后在第二页上获取html。。我先做然后再运行,但然后一步仍在首页上运行。有任何想法吗? var casper = require('casper').creat
在我的页面自动化脚本中,当我单击标签链接时,将打开一个新窗口。链接的 url 是由复杂的 javascript 生成的。 办理任务 触发后 url 变为: https://oa.phicomm.co
CasperJS(带有 phantomJS)可以直接在浏览器中运行而不是通过命令行运行吗? 我想从浏览器运行交互式测试,我从用户那里获取输入并相应地进行。我想将 casperJS 作为在浏览器中执行的
我正在尝试使用 CasperJS 将图像上传到网络表单。 我的表格看起来像这样: ... Campaign Banner
错误: casper.test property is only available using the `casperjs test` command 在我的整个代码库中搜索了“casper.tes
假设我有一组网址。我不想使用 thenOpen 函数。因为它等待每个以前的 url 被加载并且它减少了加载时间。 casper.each(hrefs,function(self,href){
我正在尝试导航到从脚本本身创建的 url。 此示例代码不像(我曾)预期的那样工作。不知道为什么:( var casper = require('casper').create({ viewpo
我有一个链接列表,我必须模拟这些链接才能使用CasperJS进行点击。他们都共享同一个类(class)。 但是,使用this.click('.click-me')仅单击第一个链接。 单击所有链接的正确
casper.then(function(){ phone_number = '7wqeqwe6'; phone_password = 'Teqweqweqw34'; }); casper.t
我如何告诉 casper 不要加载图像、css、js 视频等。所以我只对 DOM 元素感兴趣。 最佳答案 看看 CasperJS API . var casper = require('casper'
在Phantom中生成PDF时,我可以这样设置纸张大小: page.paperSize = { height: '8.5in', width: '11in', orientation: '
我是一名优秀的程序员,十分优秀!