在噩梦ejs中注入javascript函数
我得到了一个javascript函数,我需要将该函数注入到一个页面中,以获得稍后将使用的值列表。我可以使用Chrome控制台直接在网页上调用此函数,但我想在当前加载的网页上复制我在噩梦中在Chrome控制台中所做的操作 这就是功能:在噩梦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
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与网页上的脚本具有不同的作用域。作为一种解决方法,您可能希望手动将脚本注入元素。如果这种方法对您有效,请使用示例代码。我认为这可能行得通,但我愿意在这一点上尝试任何东西。如果我能看到一些示例代码,那将非常好!