如何让智能感知在 visual studio 中为 NightwatchJS 工作
How can I get intellisense working in visual studio for NightwatchJS
如何让智能感知在 visual studio 中为 NightwatchJS 工作?
使用任何本机支持的方法来解决这个问题都没有取得丰硕的成果,我花了很多时间在网上搜索其他人是如何做到这一点的,但没有运气。
为了解决这个问题,我创建了一个名为 vs-intellisense-definitions.js
的文件
然后在所有守夜人文件中,我通过以下方式为智能感知引用了它:
/// <reference path="../helpers/vs-intellisense-definitions.js" />
然后我创建了一个脚本来生成所有方法定义,这是通过导航到 Nightwatch api 网站 (http://nightwatchjs.org/api)、打开开发人员控制台和 运行 下面的脚本来完成的.输出是一个 javascript 字符串,只需将其复制并粘贴到 vs-intellisense-definitions.js
(function(){var m = $('.apimethod').map(function(i, el)
{
var methodlink = location.href.slice(0, location.href.indexOf('#') === -1 ? location.href.length : location.href.indexOf('#'))+'#'+$(el).find('h3').attr('id');
var a = {
"name":$(el).find('h3 code').first().text(),
"summary":$(el).find('p').first().text() +" Link:"+methodlink,
"params": []
};
$(el)
.find('.table-responsive table').first()
.find('tr')
.filter(function(i, el){ return $(el).find('th').size() === 0; })
.each(function(i, tr)
{
var tds = $(tr).find('td');
a.params.push({
"name":$(tds[0]).find('code').text(),
"type":$(tds[1]).text(),
"optional":$(tds[0]).find('.optional').size()>0,
"description":$(tds[2]).text()
});
});
return a;
}).toArray();
m = m.filter(function(el){ return ["Language Chains"].indexOf(el.name) === -1; });
m = Array.prototype.concat.apply([], m.map(function(el){
return el.name.split('/').map(function(subN)
{
var n = JSON.parse(JSON.stringify(el));
n.name = subN;
if(n.params.length === 0 && n.name.indexOf('(') !== -1)
{
n.params = n.name.slice(n.name.indexOf('(')+1, n.name.indexOf(')')).split(",").map(function(mn){ return {"name":mn}; });
}
var taken=[];
n.params.forEach(function(p, i)
{
if(taken.indexOf(p.name) === -1) taken.push(p.name);
else p.name = p.name+i;
});
if(n.name.indexOf('(') !== -1)n.name = n.name.slice(0, n.name.indexOf('('));
n.name = n.name.replace(/\./gim, "");
return n;
});
}));
return "\n\n\nfunction _Browser(){\n"+m.map(function(el){
return "this."+ el.name+" = function("+el.params.map(function(m){ return m.name; }).join(', ') + ")\n{\n/// <summary> "+el.summary+" </summary>\n"+ el.params.map(function(p)
{
var str = "/// <param ";
if(p.name)str += "name=\""+p.name+"\" ";
if(p.type)str += "type=\""+p.type+"\" ";
str += "optional=\""+(p.optional?"true":"false")+"\" ";
return str+"> " + (p.description || "") + " </param>";
}).join("\n")+"\n/// <returns type=\"_Browser\">Browser instance</returns>\n};\n";
}).join('\n')+"\n}\n\n\n";})();
这一切都加载和引用后,我只是通知我的 Nightwatch 测试属于浏览器参数的 'type'。例如:
/// <reference path="../helpers/vs-intellisense-definitions.js" />
module.exports = {
"Test Name": function (browser)
{ /// <param name="browser" type="_Browser">
// Intellisense success!
browser.
}
}
显然,对 API 的任何较大更改都需要重新构建文件,但这并不经常发生。
如何让智能感知在 visual studio 中为 NightwatchJS 工作?
使用任何本机支持的方法来解决这个问题都没有取得丰硕的成果,我花了很多时间在网上搜索其他人是如何做到这一点的,但没有运气。
为了解决这个问题,我创建了一个名为 vs-intellisense-definitions.js
的文件然后在所有守夜人文件中,我通过以下方式为智能感知引用了它:
/// <reference path="../helpers/vs-intellisense-definitions.js" />
然后我创建了一个脚本来生成所有方法定义,这是通过导航到 Nightwatch api 网站 (http://nightwatchjs.org/api)、打开开发人员控制台和 运行 下面的脚本来完成的.输出是一个 javascript 字符串,只需将其复制并粘贴到 vs-intellisense-definitions.js
(function(){var m = $('.apimethod').map(function(i, el)
{
var methodlink = location.href.slice(0, location.href.indexOf('#') === -1 ? location.href.length : location.href.indexOf('#'))+'#'+$(el).find('h3').attr('id');
var a = {
"name":$(el).find('h3 code').first().text(),
"summary":$(el).find('p').first().text() +" Link:"+methodlink,
"params": []
};
$(el)
.find('.table-responsive table').first()
.find('tr')
.filter(function(i, el){ return $(el).find('th').size() === 0; })
.each(function(i, tr)
{
var tds = $(tr).find('td');
a.params.push({
"name":$(tds[0]).find('code').text(),
"type":$(tds[1]).text(),
"optional":$(tds[0]).find('.optional').size()>0,
"description":$(tds[2]).text()
});
});
return a;
}).toArray();
m = m.filter(function(el){ return ["Language Chains"].indexOf(el.name) === -1; });
m = Array.prototype.concat.apply([], m.map(function(el){
return el.name.split('/').map(function(subN)
{
var n = JSON.parse(JSON.stringify(el));
n.name = subN;
if(n.params.length === 0 && n.name.indexOf('(') !== -1)
{
n.params = n.name.slice(n.name.indexOf('(')+1, n.name.indexOf(')')).split(",").map(function(mn){ return {"name":mn}; });
}
var taken=[];
n.params.forEach(function(p, i)
{
if(taken.indexOf(p.name) === -1) taken.push(p.name);
else p.name = p.name+i;
});
if(n.name.indexOf('(') !== -1)n.name = n.name.slice(0, n.name.indexOf('('));
n.name = n.name.replace(/\./gim, "");
return n;
});
}));
return "\n\n\nfunction _Browser(){\n"+m.map(function(el){
return "this."+ el.name+" = function("+el.params.map(function(m){ return m.name; }).join(', ') + ")\n{\n/// <summary> "+el.summary+" </summary>\n"+ el.params.map(function(p)
{
var str = "/// <param ";
if(p.name)str += "name=\""+p.name+"\" ";
if(p.type)str += "type=\""+p.type+"\" ";
str += "optional=\""+(p.optional?"true":"false")+"\" ";
return str+"> " + (p.description || "") + " </param>";
}).join("\n")+"\n/// <returns type=\"_Browser\">Browser instance</returns>\n};\n";
}).join('\n')+"\n}\n\n\n";})();
这一切都加载和引用后,我只是通知我的 Nightwatch 测试属于浏览器参数的 'type'。例如:
/// <reference path="../helpers/vs-intellisense-definitions.js" />
module.exports = {
"Test Name": function (browser)
{ /// <param name="browser" type="_Browser">
// Intellisense success!
browser.
}
}
显然,对 API 的任何较大更改都需要重新构建文件,但这并不经常发生。