在nightmareJS中注入javascript函数

时间:2017-07-11 16:58:15

标签: javascript node.js web-scraping nightmare

我获得了一个javascript函数,我需要将其注入到页面中,以获取稍后将使用的值列表。我可以使用Chrome控制台直接在网页上调用此功能,但我希望在当前加载的网页上的nightmareJS中复制我在Chrome控制台中所做的操作。

这是功能:

 function getList() {
  require(['Service/List'], 
  function (Service) 
  { 
    Service.getList
    ({ 
      onComplete: function (listOfServices) 
      { 
        console.log('List:success:' + JSON.stringify(listOfServices)); 

      }, 
      onFailure: function (error) 
      { 
        console.log('List:error:' + error);
      }
    });
  });
} 

getList();

我已经尝试过注入该文件但是我没有成功,我也尝试在该函数中添加额外的代码以将输出写入文件,但我不认为它被调用。

这是梦魇.JS

  describe('Open login page', () => {
it('Login', done => {
  nightmare
  .goto('http://loginURL.com')
  .wait('input[type="text"]')
  .wait('input[type="password"]')
  .insert('input[type="text"]', 'username') 
  .insert('input[type="password"]', 'password') 
  .click('input[type="submit"]')
  .evaluate(function() {
    nightmare.inject('js', 'getList.js' )
  })
  //.inject('js', 'getList.js' )
  .then(function() {
    console.log('Done');
  })
})

}) })

这是将javascript文件注入页面后的示例输出:

List:success:"Test":"https://someURL.com/resource/test","Design":"https://someURL.com/resource/Design"},"NewSpace":"https://someURL.com/resource/NewSpace","Generator":"https://Generator.someURL.com/resource/test","SomethingElse":"https://someURL.com/SomethingElse/test","Connection":"https://someURL.com/Connection/test","WorldWide":"https://someURL.com/resource/WorldWide","Vibes":"https://Vibes.someURL.com/resource/test","GoogleSearch":"https://someURL.com/resource/GoogleSearch",

我希望能够通过调用页面上的javascript文件获取该输出并将其保存到文件中,以便稍后可以使用它来调用该列表中的其他服务。

1 个答案:

答案 0 :(得分:0)

您可以阅读需要注入的本地javascript文件:

var fileData = [];
fileData.push(fs.readFileSync(path.resolve('../getList.js'), 'utf-8'));

可以通过代码

将其加载到页面的head部分
browser.win
    .evaluate(function(fileData) {
      var elem = null;
      for(var ii=0;ii<fileData.length; ii++ ) {
        elem = document.createElement('script');
        if (elem) {
          elem.setAttribute('type', 'text/javascript'); //elem.src = localjs;
          //console.log(fileData[ii]);
          elem.innerHTML = fileData[ii];
          document.head.appendChild(elem);
        }
      }

      console.log("Testing loaded scripts");
      console.log(getList());
      return "Injected Scripts";
    }, fileData)
    .then(function(result) {
      console.log(result);
    }).catch(function(error) {
      console.log("Load Error: ", error);
    });