在phantom.js中同步page.evaluate

问题描述 投票:0回答:1

我有两个page.evaluate函数,我该如何同步?我可以将函数作为参数传递给page.evaluate吗?我的功能有两个参数:selectortextNode。将没有args的函数传递给page.evaluate正在工作(如下面的代码片段所示),但我需要将参数传递给函数...我不知道该怎么做。

var page = require('webpage').create();
page.open('https://web.telegram.org/#/login', function(status) {
  console.log(status)
  if (status !== 'success') {
    console.log('Unable to access network');
  } else {
    page.evaluate(function(){
      document.querySelector("input[ng-model='credentials.phone_country']").value = ''
      document.querySelector("input[ng-model='credentials.phone_country']").click();
    })
    var keyNodes = '380';
    var keyNodeArr = keyNodes.split('');
    console.log(keyNodeArr)
    for(var i = 0; i < keyNodeArr.length; ++i){
      page.sendEvent('keypress', page.event.key[keyNodeArr[i]], null, null, null);
    }
    page.evaluate(function(){
      document.querySelector("input[ng-model='credentials.phone_number']").value = ''
      document.querySelector("input[ng-model='credentials.phone_number']").click();
    })
    keyNodes = '631091144';
    var keyNodeArr = keyNodes.split('');
    console.log(keyNodeArr)
    for(var i = 0; i < keyNodeArr.length; ++i){
      page.sendEvent('keypress', page.event.key[keyNodeArr[i]], null, null, null);
    }


    console.log("aa")
    page.render('github.png');
  }
  //phantom.exit();
});
javascript phantomjs
1个回答
0
投票

通过使用闭包我的意思是这(参见mySelectormyValue):

var page = require('webpage').create();
page.open('https://web.telegram.org/#/login', function(status) {
  console.log(status)
  if (status !== 'success') {
    console.log('Unable to access network');
  } else {
    // get these from response or from whatever other source
    var mySelector = "input[ng-model='credentials.phone_country']";
    var myValue = '';

    page.evaluate(function(){
      document.querySelector(mySelector).value = myValue;
      document.querySelector(mySelector).click();
    })
    var keyNodes = '380';
    var keyNodeArr = keyNodes.split('');
    console.log(keyNodeArr)
    for(var i = 0; i < keyNodeArr.length; ++i){
      page.sendEvent('keypress', page.event.key[keyNodeArr[i]], null, null, null);
    }
    page.evaluate(function(){
      document.querySelector(mySelector).value = myValue;
      document.querySelector(mySelector).click();
      // or use variables with other names
      // if you need them to be different from the first ones
    })
    keyNodes = '631091144';
    var keyNodeArr = keyNodes.split('');
    console.log(keyNodeArr)
    for(var i = 0; i < keyNodeArr.length; ++i){
      page.sendEvent('keypress', page.event.key[keyNodeArr[i]], null, null, null);
    }


    console.log("aa")
    page.render('github.png');
  }
  //phantom.exit();
});
© www.soinside.com 2019 - 2024. All rights reserved.