8

我是 CasperJS 的新手,我在登录此站点时遇到问题http://weibo.com/login.php

这是我尝试过的

this.fill('form#contact-form', {
    'username':    'test@test.com',
    'password':    'anypassword',

}, true);

我不能使用它,因为它没有形式。

所以我尝试了使用 sendKeys 的不同方法。

this.sendKeys('.W_input ', 'tinkerbell@gmail.com');

现在我的问题是输入文本中没有 ID,只有一个 CLASS,用户名和密码都有相同的 CLASS。如何仅使用该类在该文本框中键入内容?或者是否可以使用 XPath 使用 sendKeys?

4

3 回答 3

8

casper 支持 CSS3 选择器(tuts+ 有你应该记住的前 30 个不错的列表),所以你可以执行以下操作:

this.sendKeys('input[name=username]', 'tinkerbell@gmail.com');

于 2014-04-25T17:09:23.403 回答
5

我使用 querySelector 函数成功设置用户名和密码:

var casper = require("casper").create();
casper.start('http://www.weibo.com', function() {
    this.evaluate(function(username, password) {
        document.querySelector('input[node-type="username"]').value = username;
        document.querySelector('input[node-type="password"]').value = password;
        document.querySelector('.W_btn_g:eq(1)').click();
    }, 'your_username', 'your_password');

});

casper.then(function() {
    this.wait(50000, function() {
        this.echo("50s");
    });

});

casper.then(function() {
    this.capture('weibo.png');
});

casper.run();
于 2014-12-28T19:43:24.867 回答
-1

这是一个简单的 casper js 脚本来填写登录表单,假设它已经提到了每个字段的 id

casper.evaluate(function(username, password) { document.querySelector('input#user_email').value = username;

      document.querySelector('input#user_password').value = password;
      document.querySelector('input#login-button').click();
  }, 'email@email.com', 'password');
于 2016-07-31T23:27:57.637 回答