如何使用vim的帮助功能

set guioptions+-=m/T

更换vim的默认color schema: 将下载的color.vim文件如sonofob'sidian.vim放到/usr/share/vim/vimfiles/color文件夹下

设置命令: colorscheme sonofobsidian (没有set, scheme非schema)

vim自带的colorschema: murphy: 马铃薯/莫非就是黑底lv字比较可以的

set guifont=Monospace空格12(用转义空格)

查看vim的"环境路径": echo $VIM 输出/usr/share/vim或者/usr/local/share/vim, echo $VIMRUNTIME:输出/usr/share/vim/vim72

vim加载配置文件和插件的路径和顺序: set vimrunpath列出了, 一般包括:

/usr/share/vim=$VIM/vim72 安装路径

$VIM/vimfiles 配置文件路径

~/.vim(用户自己扩展插件), 

~/.vim/after  用户单个的

$VIM/after  :after表示修正插件,全局的

vim光标跳转和tag跳转?

首先这是两回事

光标位置跳转是指你在编辑过程中光标所经过的地方会被记忆下来,然后可以快速地向前或向后定位到历史位置,操作方法是:

ctrl+O: old向旧的,时间更早的位置跳转; ctrl+i 向新的,时间更近的位置跳转;

tag跳转: 是指将文件中的关键字(变量, 函数, typedef, 类, 结构)等提取出来,作为标签: tags, 记录下它们所在的文件和位置, 然后根据这些tags

  进行跳转. 所以它是有前提的: 要有tags文件! 要通过ctags -R产生tags. (帮助文件中本身就已经有tags?) 没有tags,是不能进行跳转的

  操作:ctrl +leftmouse, g+leftmouse , ctrl+]实现跳转, 往回跳: ctrl+T, tags列举标签, :tag <tagname>

vim中有的命令直接输入(在normal模式下) ,有的命令加冒号输入?

vi:bill joy,在ex行编辑器的基础上可视化,在/bin/下有ex命令,vim是bram对vi的扩展,所以在vi下输入大写的Q可以切换到ex

因此,vim实际上是可以支持两种命令, 一种是vi命令, 一种是ex命令:

 vi命令比较简短,一般一个字母/两个字母, 且命令不回显: 就是直接 输入

ex命令比较长, 有回显, 需要用冒号 输入.

所以有时候, 拿不准用vi命令还是ex命令, 看一下命令的长度大致也可猜测到...

ctrl-o和ctro-i?

注意这两个是通过"跳转命令"来移动的光标位置,才会被记录在"窗口"的(是窗口的,不只限定某一个文件, 同一个窗口可以记录这个窗口中打开过的

  多个文件的记录)跳转列表中, 是"跳转命令"不是 不包括 移动光标的命令hjkl和鼠标移动的命令位置, 这些位置不会被记录在跳转列表中

<font color="red" size=18>否则的话, 你想想, 如果把每次光标移动的位置都要 "让vim记住"的话, 那将是多么大的工作量和对资源(内存)的消耗啊, 很明显不合理.

跳转命令: 搜索/,? n,N G % () [[ ]] { } 标签跳转  LMH 和开始编辑文件的初始位置(即第一行)

网上的说法: "跳转" 包括如下的命令: "'"、"`"、"G"、"/"、、""?"、"n"、"N"、"%"("、")"、
"[["、"]]"、"{"、"}"、":s"、":tag"、"L"、"M"、"H" 和开始编辑新文件的命令。如果
用这些命令使光标 "跳转",那么跳转之前的光标位置会被记住

两次单引号或两次后引号, 会在最近的两个跳个位置之间切换

给出窗口的跳转列表是 :jumps :jump :ju, 跳转表最多存储100项,  其中列举了当前跳转的排序, 跳转位置的行/ 列/所在的文件等等.

可以用  nCtrl-i 向前跳n次, nctrl-o: 向后跳n次 (超过了jump列表的范围, 则不进行任何操作,无任何反应)

搜索: 对当前单词的搜索, 不必使用/, ? , 可以直接用*(向下) #(向上),

跳转到: 函数内部的局部变量的定义位置处使用: gd

查看文档的统计信息: 行/字数,字节等: g ctrl-G

关于gb2312的编码机制?

gb2312=euc-cn(extended unix code)=cp936

牵涉到三个变量:

encoding=utf-8 是指vim用于编辑器/buffers/寄存器等的编码, 相当于vim的内部编码, 根据(=)系统的locale(linux一般为utf-8), 可以实现最大兼容性,无论

    外部保存为什么格式,都可以无损转换: 相当于read, 读入,载入...

fileencoding=cp936 是指vim将内容写入到外部存储器-文件,中时的编码格式 (如果有多种file编码格式就要加s: set fileencodings = eus-cn, ucs-bom, utf-8,latin1

    相当于写出write,...

termencoding=  是指vim将buffer内容输出到term终端时的编码格式

---------------------------vim乱码解决?

当vim打开文档后,encoding=utf-8(locale决定的),fileencoding=latin1(自动编码判断机制不准导致的),termencoding=空(默认无需转换term编码),显示文件为乱码。
解决方案1:首先要修正fileencoding为cp936或者euc-cn(二者一样的,只不过叫法不同),

注意修正的方法不是:set fileencoding=cp936,这只是将文件保存为cp936,(实际上文件原本就是cp936的了)

正确的方法是重新以cp936的编码方式加载文件,(即: 在vim内部,让vim以cp936的方式去加载[读入read, 而不是写出write]文件) 为:edit ++enc=cp936,可以简写为:e ++enc=cp936

vim的帮助文件:

格式*.txt.gz, 用*???*来表示/定义一个tag标签, 用|???| 来引用一个标签tag(这个tag就相当于一个链接...)

vim系统自带的帮组文件在: /usr/share/vim/vim72/doc目录下, 格式为*.txt.gz, 是由txt文件经过gzip压缩而成的,共130个之多!

这些help文件由于放在同一个路径doc下的, 在tag引用的target中就写好了路径的, 所以它们相互直接能够引用跳转, 形成一个统一的整体,

如果把其中一个.txt.gz文件放到Desktop上, 由于路径错误,将无法链接跳转.

而且 gvim可以直接支持 打开*.txt.gz文件的...

修改linux的编码语言和字符集:

两个变量: LANG, LC_ALL:

LANG='zh_CN.gbk'

LC_ALL='zh_CN.gbk'           // 用gbk而不用cp936, 因为可能不存在cp936编码文件名

echo 'LANG=zh_CN.UTF-8' > /etc/sysconfig/i18n

echo 'LC_ALL=zh_CN.UTF-8' >> /etc/sysconfig/i18n

vim的搜索, 除了搜索字符串外,还可以搜索字符char:

在一行内搜索"字符": fx 向前搜索字符x, Fx向后, tx向前搜索,但定位在目标字符前面的一个字符上,Tx向后...

  重复fx, Fx, tx, Tx的动作用命令分号或逗号命令; ,



原文地址:https://www.cnblogs.com/bkylee/p/4916724.html