最近在我的博客上 http://foocoder.com 天天都会介绍一个vim插件,想起来园子也很久没更新了,也来更新一篇。vim
今天按读者留言的要求,介绍下文本对象。同时还会介绍我在用的几个文本相关的插件.函数
所谓文本对象,简单来讲就是以必定标准分隔符来标识一段文本,好比一个单词,一句话,一段话。spa
使用文本对象后你会发现你在vim中的移动和操做速度提高了不是一点半点。插件
在vim中编辑命令的结构以下:code
<number><command><text object or motion>
能够看到文本对象和motion的操做是彻底一致的,第一个是数字,好比3w,就向前移动三个单词。对象
文本对象大体有如下几种:ci
w s p '' "" <> [] () {} <tag>
其中w表示word,s表示句子,p表示段落,其余的就是昨天介绍过的包围符号,标签用t表示。get
文本对象的操做范围有两种,一种用i
表示,是inner的意思,即不包括单词边上的空格符,亦或是<
包围符号自己。一种用a
表示,是arround的意思,和i相反,使用a就包括了空格符或者包围符号自己。博客
文本对象的编辑命令就是vim中的几个经常使用编辑命令,分别是it
`y:复制`,`d:删除`,`c:替换`,`v:选中`
说的有点多了,来几个例子相信你们就马上理解了。(例子中*都是光标所在位置)
好比:
<*h2>Sample Title</h2>
按下cit
,文本变为:
<h2>*</h2>
再好比:
console.log(“stay hungry,” + “stay *foolish”)
按下da"
,文本变为:
console.log("stay hungry," +*)
再按下di)
,文本变为:
console.log()
好比
Hello Worl*d
按下diw
,文本变为:
Hello
很容易理解是否是?有没有发现为何说文本对象会很是方便了?不管光标在文本的哪一个位置,均可以直接操做整个文本。体验箭步如飞的感受吧。
vim还容许使用脚原本自定义文本对象,这就是咱们今天要介绍的插件了,这些插件自定义了一些文本对象。
1.CamelCaseMotion
该插件是把驼峰词语的每一个单词分开,举个例子:
get*ElementsByClassName
按下di,w
,则文本变为:
getByClassName
很是方便。
2.argtextobj
该插件定义了函数内的参数文本对象。好比:
foo(text, ti*mes, option) {}
按下daa
,则文本变为:
foo(text, option) {}
今天暂时就介绍到这里。都快0点了,赶忙发出来。任何问题均可以回复给我。