VIM的JavaScript补全
最近微软出了个Visual Studio Code,听说很diao,尤其是对JavaScript的补全支持很令人惊艳!
如果你是一个vim党,那么请淡定!
在JavaScript开发过程中,使用vim内置的ins-completion
再加上一些插件,我们同样可以获得很牛逼的completion支持!
ins-completion
vim其实已经提供了很好的代码补全支持。
整行
快捷键:<C-X><C-L>
文件名
快捷键:<C-X><C-F>
当前文件中的关键字
快捷键:<C-X><C-P>
或<C-X><C-N>
complete
选项所指定的范围中的关键字
快捷键:<C-N>
或<C-P>
<C-N>
、<C-P>
跟<C-X><C-N>
、<C-X><C-P>
类似,但是查找范围更广,不局限于当前文件。
如上图所示,我打开两个文件,在src/echarts.js
中补全src/component.js
中的关键字,就可以使用<C-N>
或<C-P>
。
具体查找范围由complete
选项所规定,详见:help E535
。
dictionary
中的关键字
快捷键:<C-X><C-K>
假设你有一个javascript.dict
文件,其内容如下:
1 | Promise Proxy let class extends |
设置:set dictionary+=/path/to/es6.dict
之后就可以用<C-X><C-K>
来补全这些关键字了。
omni completion
快捷键:<C-X><C-O>
这个是基于语义上的补全,vim会猜测光标之前的关键词,然后给出补全。
更多补全方式,请看:help ins-completion
。
YouCompleteMe
按键太多了,真不开心…
先上一个自动打开候选菜单的插件,再继续吹牛逼吧…
YouCompleteMe是一个不错的选择,补全速度比neocomplete快。
基本配置如下:
1 | let g:ycm_min_num_of_chars_for_completion = 3 |
现在,对于关键字补全、路径补全、omni completion
,YouCompleteMe可以自动打开补全菜单了。
恩,看起来ins-completion
还不错,但是跟vscode比起来还不够!
vim的omni completion
实际上可以支持更牛逼的completion,于是有了tern。
tern_for_vim
tern_for_vim
是ternjs给vim量身定做的插件,它实际上是给javascript实现了一个新的omnifunc
,叫做tern#Complete
。
当我们按下<C-X><C-O>
时,vim实际上就是调用omnifunc
。
tern_for_vim
改写了omnifunc
,接管了vim的omni completion
。
vim安装了tern_for_vim
之后,在项目的根目录中新建一个配置文件.tern-project
,以echarts为例,配置如下:
1 | { |
libs
字段指明要导入哪些库,tern内置了以下几种库:
- browser
- chai
- ecma5,默认自动导入
- ecma6
- jquery
- underscore
我们现在只配置了browser,看看会发生什么事情?
如果你的项目还用到了jquery,那么你可以把jquery加到.tern-project
的libs字段中,效果如下:
plugins
更猛,可以补全模块化的代码,tern支持以下几种插件:
- angular.js
- complete_string.js
- component.js
- doc_comment.js,默认自动启用
- nodejs
- requirejs
看看echarts项目配置了requirejs插件之后会怎么样?
碉堡了,有木有!
我们再也不用担心某个模块到底提供了哪些方法,require它,输入点号,然后提示,你所要做的就是选择!
如果第三方库在代码中提供足够的文档注释,我们甚至都不需要再去查文档了!
哦,稍等,听说vscode还支持nodejs的补全。
在nodejs项目下配置一下.tern-project
:
1 | { |
看看tern对nodejs项目的支持如何?
嗯,貌似还可以!
小结
如果你是一个vim粉丝,那希望本文对你有所帮助!