必威-必威-欢迎您

必威,必威官网企业自成立以来,以策略先行,经营致胜,管理为本的商,业推广理念,一步一个脚印发展成为同类企业中经营范围最广,在行业内颇具影响力的企业。

我选择一个能极大提高自己开发效率的编辑器必

2019-09-19 08:45 来源:未知

Vim常用插件——前端开发工具系列

2015/08/16 · HTML5 · vim, 插件

原文出处: AlloyTeam   

作为一名开发者,应该对编辑器之神Vim)与神之编辑器Emacs有所耳闻吧。编辑器之战的具体细节有兴趣的童鞋可以google之。

Vim最大的特点是打开速度快,功能强大,一旦掌握了其中的命令,编程过程双手就不需要离开键盘了。

用习惯了Vim的另一个好处是在linux下可以很轻松地用vi来处理文件,当然emacs也可以做默认编辑器,但是不是每台机器都有安装Emacs。

今天主要给大家介绍Vim在前端领域的一些常用插件:

NERD_tree.vim
[NERD_tree.vim]-主要功能是一款文件浏览器,可以查看文件目录结构打开相应的文件

必威 1vim_cheat_sheet_for_programmers.png

<pre>

Ubuntu 16.04 下安装Vim

默认已经安装了VIM-tiny

linuxidc@linuxidc:~$ locate vi | grep 'vi$' |xargs ls -al
lrwxrwxrwx 1 root root   17 12月  9 21:12 /etc/alternatives/vi -> /usr/bin/vim.tiny
lrwxrwxrwx 1 root root   20 12月  9 21:13 /usr/bin/vi -> /etc/alternatives/vi
-rw-r--r-- 1 root root   59 12月 23  2015 /usr/lib/x86_64-linux-gnu/espeak-data/voices/asia/vi
-rw-r--r-- 1 root root 1415 11月 11  2015 /usr/share/bash-completion/completions/ldapvi
-rw-r--r-- 1 root root  475 4月  21  2016 /var/lib/dpkg/alternatives/vi

下面我们以Ubuntu14.04(Unity)安装完整版VIM(VIM-basic)为例:

在终端输入以下命令,则会自动安装:

sudo apt-get install vim

自动安装完之后,可以使用以下命令进行查看:

已经添加到系统

update-alternatives --display vi

查看版本

vim --version

1.mark.vim

mark.vim主要的功能是变量的高亮。

选中要高亮的词,使用 m 来使其高亮,多个词的高亮会显示为不同的颜色,在不需要查找的时候以及代码review的时候使用效果还是挺不错的,

使用n可以去除所选的词的高亮。

更多详情可以点击插件主页了解。

ps: 查找单词可以使用 * 这个命令来进行快速搜索

下面总结一些命令
ctrl + w + h 光标 focus 左侧树形目录ctrl + w + l 光标 focus 右侧文件显示窗口ctrl + w + w 光标自动在左右侧窗口切换 ctrl + w + r 移动当前窗口的布局位置

常言道:工欲善其事,必先利其器 ,作为一个程序员,一个常用的工具就是编辑器,我选择一个能极大提高自己开发效率的编辑器vim(有些人可能选择emacs)。而vim编辑器方面具有以下几种特性:

<h2>NERD_tree.vim </h2>
<pre><h5>[NERD_tree.vim]-主要功能是一款文件浏览器,可以查看文件目录结构打开相应的文件</h5></pre>

VIM配置

注:只对各个用户在自己的当前目录下的.vimrc修改的话,修改内容只对本用户有效,要想全部有效,可以修改/etc/vim/vimrc.

在终端下使用vim进行编辑时,默认情况下,编辑的界面上是没有显示行号、语法高亮度显示、智能缩进等功能的。为了更好的在vim下进行工作,需要手动设置一个配置文件:.vimrc。

启动vim时,当前用户根目录下的.vimrc文件会被自动读取,该文件可以包含一些设置甚至脚本,所以,一般情况下把.vimrc文件创建在当前用户的根目录下比较方便,即创建的命令为

$vi ~/.vimrc

设置完后 :x或者:x或者wq 进行保存退出即可。

下面给出一个例子,其中列出了经常用到的设置,详细的设置信息请参照参考资料

2.zencoding.vim

zencoding.vim 后来改名为Emmet.vim,主要功能是实现代码的快速编写。

具体教程可以参见官方的网站

个人感受是做页面重构的时候用得比较多,通过命令可以快速生成html的结构,提高了前端开发的生产力。

快捷键
o 在已有窗口中打开文件、目录或书签,并跳到该窗口go 在已有窗口 中打开文件、目录或书签,但不跳到该窗口t 在新 Tab 中打开选中文件/书签,并跳到新 TabT 在新 Tab 中打开选中文件/书签,但不跳到新 Tabi split 一个新窗口打开选中文件,并跳到该窗口gi split 一个新窗口打开选中文件,但不跳到该窗口s vsplit 一个新窗口打开选中文件,并跳到该窗口gs vsplit 一个新 窗口打开选中文件,但不跳到该窗口! 执行当前文件O 递归打开选中 结点下的所有目录x 合拢选中结点的父目录X 递归 合拢选中结点下的所有目录e Edit the current dif双击 相当于 NERDTree-o中键 对文件相当于 NERDTree-i,对目录相当于 NERDTree-eD 删除当前书签P 跳到根结点p 跳到父结点K 跳到当前目录下同级的第一个结点J 跳到当前目录下同级的最后一个结点k 跳到当前目录下同级的前一个结点j 跳到当前目录下同级的后一个结点C 将选中目录或选中文件的父目录设为根结点u 将当前根结点的父目录设为根目录,并变成合拢原根结点U 将当前根结点的父目录设为根目录,但保持展开原根结点r 递归刷新选中目录R 递归刷新根结点m 显示文件系统菜单 #!!!然后根据提示进行文件的操作如新建,重命名等cd 将 CWD 设为选中目录I 切换是否显示隐藏文件f 切换是否使用文件过滤器F 切换是否显示文件B 切换是否显示书签q 关闭 NerdTree 窗口? 切换是否显示 Quick Help
命令模式
:tabnew [++opt选项] [+cmd] 文件 建立对指定文件新的tab:tabc 关闭当前的 tab:tabo 关闭所有其他的 tab:tabs 查看所有打开的 tab:tabp 前一个 tab:tabn 后一个 tab标准模式下:
gT 前一个 tabgt 后一个 tabMacVim 还可以借助快捷键来完成 tab 的关闭、切换cmd+w 关闭当前的 tabcmd+{ 前一个 tabcmd+} 后一个 tab

  • 跨平台及统一环境无论是在windows还是在*nix,vim是一个很完美的跨平台文本编辑器,甚至可以直接在服务器平台CentOS,Ubuntu等直接配置使用,配置文件大同小异,操作习惯基本相同。

  • 定制化及可扩展vim提供一个vimrc的配置文件来配置vim,并且自己可以定制一些插件来实现文件浏览(NERD Tree),代码补全(YouCompleteMe,语法检查(syntastic),文件模糊搜索,显示vim状态栏(Vim Powerline),主题颜色,显示文件结构等多种功能。

  • 高效命令行使用vim编辑文本,只需在键盘上操作就可以,根本无需用到鼠标。就拿光标移动来说,与重复击键、一个字符一个字符或一行一行移动相比,按一次键就能以词、行、块或函数为单位移动,效率高得多。有时一些重复删除、粘帖的操作,也只需一条命令就可以完成,甚至你可以用键映射来简化或组合多种命令来提高效率。

下面总结一些命令

ctrl + w + h  光标 focus 左侧树形目录
ctrl + w + l  光标 focus 右侧文件显示窗口
ctrl + w + w  光标自动在左右侧窗口切换 
ctrl + w + r  移动当前窗口的布局位置

基本配置[1] [2]

"开启语法高亮
syntax on
"依文件类型设置自动缩进
filetype indent plugin on

"显示当前的行号列号:
set ruler
"在状态栏显示正在输入的命令
set showcmd

"关闭/打开配对括号高亮
"NoMatchParen
DoMatchParen
行号的显示与隐藏[3]:

"显示行号:
set number
"为方便复制,用<F2>开启/关闭行号显示:
nnoremap <F2> :set nonumber!<CR>:set foldcolumn=0<CR>

启用Modeline(即允许被编辑的文件以注释的形式设置Vim选项,详见Vim Wiki: Modeline magic)[4]:

set modeline

如果终端使用的是深色背景:

"为深色背景调整配色
set background=dark

3.ctrlp.vim

ctrlp.vim主要功能是对文件以及buffer进行模糊查询,快速打开文件。

操作实例如下图所示:

必威 2

必威 3

在知道文件名的情况下,使用ctrl + p打开此插件,输入文件名,实则是文件名开头几个字母就可以快速打开文件。

ps:如果当前的文件已经保存好,那么会直接替换成搜索到的文件,如果没有保存的,会进行窗口的分隔类似与sp的命令。

所以在对比文件的情况下我一般会用vsp来分割窗口或者tabnew一个新的tab,再打开新的文件。

如果需要查其他目录或者忘记了文件名的话,就可以使用下面的插件NERD_tree了。

mark.vim
[mark.vim]-主要的功能是变量的高亮,允许你在文本中放置自定义的标记
在编辑的时候,你忽然想起来需要修改同一个文档的另一个地方,但又想记住当前的位置,以便稍后再回来编辑。应该怎么做呢?vim中我们可以对文本进行标记,这个概念类似于visual studio中的书签,目的是方便vim编辑器在文档的不同位置间跳转。正常情况下,这意味着要移动到那个位置,编辑,然后再移回来。这样很费事,也容易忘记刚才所在的位置。有更聪明的办法。移动光标到下述文本的第5行(John Lennon的名言)。用ma创建一个名为'a'的标记。移动光标到任一地方,比如,4j。按下’a(即,单引号加上标记的名字),瞧Vim跳到了刚才做标记的那一行的行首。如果要跳到做标记的位置,按下‘a(即,上排数字键1左边那个键)。可以使用任一字母(a-zA-Z)去命名一个标记,意味着一个文件里最多可以有52个命名标记。 添加标记 将光标移到某一行,使用 ma 命令添加标记。其中,m 是标记命令,a 是所做标记的名称。可以使用小写字母 a-z 或大写字母 A-Z 中的任意一个做为标记名称。小写字母的标记,仅用于当前缓冲区;而大写字母的标记,则可以跨越不同的缓冲区。例如,你正在编辑 File1,但仍然可以使 用'A 命令,移动到 File2 中创建的标记A。跳转标记 创建标记后,可以使用 'a 命令,跳转到指定标记行的首个非空字符。这里 ' 是单引号。也可以使用 'a 命令,移到所做标记时的光标位置。这里'是反引号(也就是数字键1左边的那一个)。列出标记 利用:marks命令,可以列出所有标记。这其中也包括一些系统内置的特殊标记(Special marks):. ——最近编辑的位置0-9——最近使用的文件∧ ——最近插入的位置' ——上一次跳转前的位置" ——上一次退出文件时的位置[ ——上一次修改的开始处] ——上一次修改的结尾处删除标记 如果删除了做过标记的文本行,那么所做的标记也就不存了。我们不仅可以利用标记来快速移动,而且还可以使用标记来删除文本,例如:在某一行用ma做了标记,然后就可以使用d'a来删掉这一行。当然,我们也可以使用y'a命令就可以来复制这一行了。使用:delmarks a b c命令,可以删除某个或多个标记;而:delmarks! 命令,则会删除所有标记。利用:help mark-motions命令,可以查看关于标记的更多帮助信息。命令小结m ——创建标记' ——移动到标记的文本行首 ——移动到标记的光标位置:marks ——列示所有标记:delmarks ——删除指定标记:delmarks! ——删除所有标记

如果你需要配置vim,只需在Home目录创建一个~/.vimrc文件即可以配置vim了,可以参考我的vimrc配置文件。由于我需要安装插件,并且将需要安装的插件列表分离到另外一个文件~/.vimrc.bundles,这个文件也是存放在Home目录,文件内容可以参考vimrc.bundles。若想加载~/.vimrc.bundles文件,必须在~/.vimrc文件加入以下代码片段:

快捷键

<pre>
o 在已有窗口中打开文件、目录或书签,并跳到该窗口
go 在已有窗口 中打开文件、目录或书签,但不跳到该窗口
t 在新 Tab 中打开选中文件/书签,并跳到新 Tab
T 在新 Tab 中打开选中文件/书签,但不跳到新 Tab
i split 一个新窗口打开选中文件,并跳到该窗口
gi split 一个新窗口打开选中文件,但不跳到该窗口
s vsplit 一个新窗口打开选中文件,并跳到该窗口
gs vsplit 一个新 窗口打开选中文件,但不跳到该窗口! 执行当前文件
O 递归打开选中 结点下的所有目录
x 合拢选中结点的父目录
X 递归 合拢选中结点下的所有目录
e Edit the current dif
双击 相当于 NERDTree-o中键 对文件相当于 NERDTree-i,对目录相当于 NERDTree-eD 删除当前书签
P 跳到根结点
p 跳到父结点
K 跳到当前目录下同级的第一个结点
J 跳到当前目录下同级的最后一个结点
k 跳到当前目录下同级的前一个结点
j 跳到当前目录下同级的后一个结点
C 将选中目录或选中文件的父目录设为根结点
u 将当前根结点的父目录设为根目录,并变成合拢原根结点
U 将当前根结点的父目录设为根目录,但保持展开原根结点
r 递归刷新选中目录R 递归刷新根结点
m 显示文件系统菜单 #!!!然后根据提示进行文件的操作如新建,重命名等
cd 将 CWD 设为选中目录I 切换是否显示隐藏文件
f 切换是否使用文件过滤器
F 切换是否显示文件
B 切换是否显示书签
q 关闭 NerdTree 窗口
? 切换是否显示 Quick Help
</pre>

<pre>
<h5>命令模式</h5>
:tabnew [++opt选项] [+cmd] 文件 建立对指定文件新的tab
:tabc 关闭当前的 tab
:tabo 关闭所有其他的 tab
:tabs 查看所有打开的 tab
:tabp 前一个 tab
:tabn 后一个 tab
<br />
<h4>标准模式下:</h4>
gT 前一个 tab
gt 后一个 tab
<br />
<p> MacVim 还可以借助快捷键来完成 tab 的关闭、切换cmd+w 关闭当前的 tabcmd+{ 前一个 tabcmd+} 后一个 tab</p>
</pre>
</pre>

<pre>
<h2>mark.vim </h2>
<pre><h5>[mark.vim]-主要的功能是变量的高亮,允许你在文本中放置自定义的标记</h5> 在编辑的时候,你忽然想起来需要修改同一个文档的另一个地方,但又想记住当前的位置,以便稍后再回来编辑。应该怎么
做呢?vim中我们可以对文本进行标记,这个概念类似于visual studio中的书签,目的是方便vim编辑器在文档的不同位置
间跳转。正常情况下,这意味着要移动到那个位置,编辑,然后再移回来。这样很费事,也容易忘记刚才所在的位置。
有更聪明的办法。移动光标到下述文本的第5行(John Lennon的名言)。用ma创建一个名为'a'的标记。移动光标
到任一地方,比如,4j。按下’a(即,单引号加上标记的名字),瞧Vim跳到了刚才做标记的那一行的行首。如果要跳到做标记
的位置,按下‘a(即`,上排数字键1左边那个键)。可以使用任一字母(a-zA-Z)去命名一个标记,意味着一个文件里最多可以
有52个命名标记。
</pre>
<pre>
<h5>添加标记</h5>
将光标移到某一行,使用 ma 命令添加标记。其中,m 是标记命令,a 是所做标记的名称。
可以使用小写字母 a-z 或大写字母 A-Z 中的任意一个做为标记名称。小写字母的标记,仅用于当前缓冲区;而大写字母的
标记,则可以跨越不同的缓冲区。例如,你正在编辑 File1,但仍然可以使 用'A 命令,移动到 File2 中创建的标记A。<br />
<h5>跳转标记</h5>
创建标记后,可以使用 'a 命令,跳转到指定标记行的首个非空字符。这里 ' 是单引号。也可以使用 'a 命令,移到所做
标记时的光标位置。这里'是反引号(也就是数字键1左边的那一个)。
<br />
<h5>列出标记</h5>
利用:marks命令,可以列出所有标记。这其中也包括一些系统内置的特殊标记(Special marks):

. ——最近编辑的位置
0-9——最近使用的文件
∧ ——最近插入的位置
' ——上一次跳转前的位置
" ——上一次退出文件时的位置
[ ——上一次修改的开始处
] ——上一次修改的结尾处
<br />
<h5>删除标记</h5>
如果删除了做过标记的文本行,那么所做的标记也就不存了。我们不仅可以利用标记来快速移动,而且还可以使用标记来删除
文本,例如:在某一行用ma做了标记,然后就可以使用d'a来删掉这一行。当然,我们也可以使用y'a命令就可以来复制这一行
了。
使用:delmarks a b c命令,可以删除某个或多个标记;而:delmarks! 命令,则会删除所有标记。
利用:help mark-motions命令,可以查看关于标记的更多帮助信息。

命令小结

m ——创建标记
' ——移动到标记的文本行首
` ——移动到标记的光标位置
:marks ——列示所有标记
:delmarks ——删除指定标记
:delmarks! ——删除所有标记
</pre>
</pre>
<pre>
<h2>commentary.vim </h2>
<h5>[commentary.vim]-主要功能是可以批量注释单行或多行以及去除注释;</h5>
gc:Visual模式下可以注释选中的行
gcc:普通模式下可以快速注释一行
gcu:可以撤销注释
</pre>

<pre><h2>multiple_cursors.vim</h2><br /><h5>[multiple_cursors.vim]-多行、多光标编辑</h5>
通过按 Ctrl + n 来多重选取。一旦选取完成,便可配合 Vim 既有的命令对其进行编辑处理。最后按 Esc 可以退出多重选取<br />状态。此外,你也可以使用 MultipleCursorsFind 命令通过正则表达式来进行多重选取和编辑。
</pre>

<pre><h2>ctrlp.vim</h2><h5>[ctilp.vim]-主要功能是对系统文件进行搜索</h5>
ctrl + j/k 进行上下选择
ctrl + x 在当前窗口水平分屏打开文件
ctrl + v 同上, 垂直分屏
ctrl + t 在tab中打开
</pre>
<pre><h2>neocomplcache</h2><h5>[neocomplcache.vim]-自动补全插件</h5>
ctrl+n-对补全代码向下选择
ctrl+p-对补全代码向上选择
</pre>
<pre><h2>emmet.vim</h2><h5>[emmet.vim]-HTML超级编写利器,利用简写语法达到编写目的。</h5>
Emmet的基本用法:先写简写形式,然后用"<Ctrl+y>,"将其转成HTML代码
基本规则:
(1):E 代表HTML标签
(2):E#id 代表标签E有id属性
(3):E.class 代表E有class属性
(4):E[attr=foo] 代表某个特定属性
(5):E{info} 代表标签E包含的内容是info
(6):E>N 代表N是E的子元素
(7):E+N 代表N是E的同级元素
(8):E^N 代表N是E的上级元素
</pre>

<pre><h2>vim-surround</h2><h5>[vim-surround]-这个插件可以快速的为字符串包围/改变或去除引号/括号或者HTML标签</h5>
<h5>为单个单词包围</h5>
ysiw + '/"/(/[/{ :在命令模式下, 就可以为光标下的一个单词包围上 '/"/(/[/{

比如
ysiw' :为光标下的单词包围上单引号
ysiw" :为光标下单词包围上双引号, 依此类推.
vim-surround 同时还支持包围html标签, 将光标放到某单词试试下面指令:ysiw<p>ysiw<p class="meta">
yssb :包围一行,可以快速为一行包围圆括号,.
yss + '/"/(/[/{ : 可以为正行快速包围相应的引号/括号
比如
yss" :为一行包围双引号
<br />
<h5>更改包围</h5>
cs :可以更改包围,

比如
cs'" :是将单引号变成双引号
cs"( :是将双引号变成圆括号
vim-surround支持将括号或者引号变更为html标签, 试试命令cs'<p> :将单引号换成 <p>标签
<br />
<h5>去除包围</h5>
ds:指令可以取出包围, 后面需跟包围的内容,
ds":是去除双引号包围, ``
</pre>

插件管理

下文的配置很多都依赖于第三方开发的 Vim 插件。为了方便地安装和维护这些插件,推荐先安装一种插件管理工具,目前较为流行的是 Vundle 和 pathogen。二者功能类似,但 Vundle 的配置更灵活, pathogen 则相对简洁。二者都能很好地与Git结合,安装插件十分方便。

如果你使用 Git 管理你的配置文件,那么还可以将 Pathogen 或 Vundle 与 Git 的 Submodule 功能管理插件结合[5],使得在多台电脑间同步插件及在本地更新插件变得十分便捷。

# 在存放配置文件的主文件夹下,添加一个 submodule
git submodule add https://github.com/gmarik/vundle.git .vim/bundle/vundle

# 用类似的办法添加多个插件后,以后升级插件只需:
git submodule update

# 如果其它电脑 checkout 出配置文件后,要先:
git submodule init

插件管理工具无需通过系统的包管理系统安装,只要将需要的文件放在 ~/.vim/目录中即可。这样,一套配置文件也可以方便地用在多个不同的系统环境中。

4.NERD_tree.vim

NERD_tree.vim主要功能是一款文件浏览器,可以查看文件目录结构打开相应的文件。

具体演示如下图所示:

必威 4

我是使用绑定的快捷键F4来打开文件浏览器,光标在文件浏览器中可以用jk来移动,回车键可以打开文件,按q可以退出文件浏览器。

commentary.vim
[commentary.vim]-主要功能是可以批量注释单行或多行以及去除注释;
gc:Visual模式下可以注释选中的行gcc:普通模式下可以快速注释一行gcu:可以撤销注释
multiple_cursors.vim
[multiple_cursors.vim]-多行、多光标编辑
通过按 Ctrl + n 来多重选取。一旦选取完成,便可配合 Vim 既有的命令对其进行编辑处理。最后按 Esc 可以退出多重选取状态。此外,你也可以使用 MultipleCursorsFind 命令通过正则表达式来进行多重选取和编辑。
ctrlp.vim
[ctilp.vim]-主要功能是对系统文件进行搜索
ctrl + j/k 进行上下选择ctrl + x 在当前窗口水平分屏打开文件ctrl + v 同上, 垂直分屏ctrl + t 在tab中打开
neocomplcache
[neocomplcache.vim]-自动补全插件
ctrl+n-对补全代码向下选择ctrl+p-对补全代码向上选择
emmet.vim
[emmet.vim]-HTML超级编写利器,利用简写语法达到编写目的。
Emmet的基本用法:先写简写形式,然后用"<Ctrl+y>,"将其转成HTML代码基本规则:(1):E 代表HTML标签(2):E#id 代表标签E有id属性(3):E.class 代表E有class属性(4):E[attr=foo] 代表某个特定属性(5):E{info} 代表标签E包含的内容是info(6):E>N 代表N是E的子元素(7):E+N 代表N是E的同级元素(8):E^N 代表N是E的上级元素
vim-surround
[vim-surround]-这个插件可以快速的为字符串包围/改变或去除引号/括号或者HTML标签
为单个单词包围
ysiw + '/"/(/[/{ :在命令模式下, 就可以为光标下的一个单词包围上 '/"/(/[/{比如ysiw' :为光标下的单词包围上单引号ysiw" :为光标下单词包围上双引号, 依此类推.vim-surround 同时还支持包围html标签, 将光标放到某单词试试下面指令:ysiwysiw<p class="meta">yssb :包围一行,可以快速为一行包围圆括号,.yss + '/"/(/[/{ : 可以为正行快速包围相应的引号/括号比如yss" :为一行包围双引号
更改包围
cs :可以更改包围,比如cs'" :是将单引号变成双引号cs"( :是将双引号变成圆括号vim-surround支持将括号或者引号变更为html标签, 试试命令cs':将单引号换成
标签
去除包围
ds:指令可以取出包围, 后面需跟包围的内容,ds":是去除双引号包围, ``

if filereadable(expand("~/.vimrc.bundles")) source ~/.vimrc.bundlesendif

代码补全

Vim 7已经内置了代码补全功能[6],补全操作可分为两种:

TAG标签:
版权声明:本文由必威发布于必威-前端,转载请注明出处:我选择一个能极大提高自己开发效率的编辑器必