如何让智能感知在 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 的任何较大更改都需要重新构建文件,但这并不经常发生。