zoukankan      html  css  js  c++  java
  • 每日vim插件--vim中的文本对象及相关插件

    最近在个人博客上 http://foocoder.com  每天都会介绍一个vim插件,想起来园子也好久没更新了,也来更新一篇。

    今天按读者留言的要求,介绍下文本对象。同时还会介绍我在用的几个文本相关的插件.

    所谓文本对象,简单来说就是以一定标准分隔符来标识一段文本,比如一个单词,一句话,一段话。

    使用文本对象后你会发现你在vim中的移动和操作速度提升了不是一点半点。

    在vim中编辑命令的结构如下:

     <number><command><text object or motion>
    

    可以看到文本对象和motion的操作是完全一致的,第一个是数字,比如3w,就向前移动三个单词。

    文本对象大致有以下几种:

    w  s  p '' ""  <>  []  ()  {} <tag>
    

    其中w表示word,s表示句子,p表示段落,其他的就是昨天介绍过的包围符号,标签用t表示。

    文本对象的操作范围有两种,一种用i表示,是inner的意思,即不包括单词边上的空格符,亦或是<包围符号本身。一种用a表示,是arround的意思,和i相反,使用a就包括了空格符或者包围符号本身。

    文本对象的编辑命令就是vim中的几个常用编辑命令,分别是

    `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点了,赶紧发出来。任何问题都可以回复给我。

  • 相关阅读:
    logback-spring.xml配置文件详解
    SpringBoot-Controller接收参数的几种常用方式
    spring boot配置定时任务设置
    SpringCloud 配置文件 application.yml和 bootstrap.yml区别
    ajax/get请求
    ajax封装2
    ajax封装1
    楼层特效
    旋转动画
    联动动画
  • 原文地址:https://www.cnblogs.com/noTice520/p/3668110.html
Copyright © 2011-2022 走看看