在噩梦ejs中注入javascript函数

在噩梦ejs中注入javascript函数,javascript,node.js,web-scraping,nightmare,Javascript,Node.js,Web Scraping,Nightmare,我得到了一个javascript函数,我需要将该函数注入到一个页面中,以获得稍后将使用的值列表。我可以使用Chrome控制台直接在网页上调用此函数,但我想在当前加载的网页上复制我在噩梦中在Chrome控制台中所做的操作 这就是功能: function getList() { require(['Service/List'], function (Service) { Service.getList ({ onComplete: function

我得到了一个javascript函数,我需要将该函数注入到一个页面中,以获得稍后将使用的值列表。我可以使用Chrome控制台直接在网页上调用此函数,但我想在当前加载的网页上复制我在噩梦中在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();
我尝试过注入该文件,但没有成功,我还尝试过向该函数添加额外的代码以将输出写入文件,但我认为根本没有调用它

这是噩梦

  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文件获得该输出,并将其保存到一个文件中,以便以后可以使用它调用该列表中的其他服务。

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

var fileData = [];
fileData.push(fs.readFileSync(path.resolve('../getList.js'), 'utf-8'));
可通过以下代码将其加载到页面的标题部分:

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);
    });
browser.win
.evaluate(函数(文件数据){
var-elem=null;

对于(var ii=0;iiI)来说,inject与网页上的脚本具有不同的作用域。作为一种解决方法,您可能希望手动将脚本注入元素。如果这种方法对您有效,请使用示例代码。我认为这可能行得通,但我愿意在这一点上尝试任何东西。如果我能看到一些示例代码,那将非常好!