终端中的编辑器
vi
vi
是Visual interface
的简称,是Linux
中 最经典 的文本编辑器vi
的核心设计思想 —— 让程序员的手指始终保持在键盘的核心区域,就能完成所有的编辑操作vi
编辑器在 系统管理、服务器管理 编辑文件时,其功能永远不是图形界面的编辑器能比拟的
vi
的特点: * 没有图形界面 的 功能强大 的编辑器 * 只能是编辑 文本内容,不能对字体、段落进行排版 * 不支持鼠标操作 * 没有菜单 * 只有命令
vim
vim = vi improved
-
vim
是从vi
发展出来的一个文本编辑器,支持 代码补全、编译 及 错误跳转 等方便编程的功能特别丰富,在程序员中被广泛使用,被称为 编辑器之神 -
安装:
sudo apt install vim
打开和新建文件, 在终端中输入 vi
在后面跟上文件名 即可:
$ vi 文件名
- 如果文件已经存在,会直接打开该文件
- 如果文件不存在,会新建一个文件
-
在日常工作中,有可能会遇到 打开一个文件,并定位到指定行 的情况
-
例如:在开发时,知道某一行代码有错误,可以 快速定位 到出错代码的位置
-
这个时候,可以使用以下命令打开文件
$ vi 文件名 +行数
提示:如果只带上 +
而不指定行号,会直接定位到文件末尾
- 如果
vi
异常退出,在磁盘上可能会保存有 交换文件 - 下次再使用
vi
编辑该文件时,会看到以下屏幕信息,按下字母d
可以 删除交换文件 即可
提示:按下键盘时,注意关闭输入法
- 命令模式
- 打开文件首先进入命令模式,是使用
vi
的 入口 - 通过 命令 对文件进行常规的编辑操作,例如:定位、翻页、复制、粘贴、删除……
- 在其他图形编辑器下,通过 快捷键 或者 鼠标 实现的操作,都在 命令模式 下实现
- 打开文件首先进入命令模式,是使用
- 编辑模式 —— 正常的编辑文字
- 末行模式 —— 执行 保存、退出 等操作
- 要退出
vi
返回到控制台,需要在末行模式下输入命令 - 末行模式 是
vi
的 出口
- 要退出
- 要熟练使用
vi
,首先应该学会怎么在 命令模式 下样快速移动光标 - 编辑操作命令,能够和 移动命令 结合在一起使用
vi
中使用 空行 来区分段落- 在程序开发时,通常 一段功能相关的代码会写在一起 —— 之间没有空行
- 在程序世界中,
()
、[]
、{}
使用频率很高,而且 都是成对出现的
- 在开发时,某一块代码可能需要稍后处理,例如:编辑、查看
- 此时先使用
m
增加一个标记,这样可以 在需要时快速地跳转回来 或者 执行其他编辑操作 - 标记名称 可以是
a~z
或者A~Z
之间的任意 一个 字母 - 添加了标记的 行如果被删除,标记同时被删除
- 如果 在其他行添加了相同名称的标记,之前添加的标记也会被替换掉
- 学习
复制
命令前,应该先学会 怎么样选中 要复制的代码 - 在
vi
中要选择文本,需要先使用Visual
命令切换到 可视模式 vi
中提供了 三种 可视模式,可以方便程序员选择 选中文本的方式- 按
ESC
可以放弃选中,返回到 命令模式
- 可视模式下,可以和 移动命令 连用,例如:
ggVG
能够选中所有内容
- 在学习编辑命令之前,先要知道怎样撤销之前一次 错误的 编辑动作!
提示:如果使用 可视模式 已经选中了一段文本,那么无论使用 d
还是 x
,都可以删除选中文本
- 删除命令可以和 移动命令 连用,以下是常见的组合命令:
* dw # 从光标位置删除到单词末尾
* d0 # 从光标位置删除到一行的起始位置
* d} # 从光标位置删除到段落结尾
* ndd # 从光标位置向下连续删除 n 行
* d代码行G # 从光标所在行 删除到 指定代码行 之间的所有代码
* d'a # 从光标所在行 删除到 标记a 之间的所有代码
复制、粘贴
vi
中提供有一个 被复制文本的缓冲区- 复制 命令会将选中的文字保存在缓冲区
- 删除 命令删除的文字会被保存在缓冲区
- 在需要的位置,使用 粘贴 命令可以将缓冲区的文字插入到光标所在位置
提示
- 命令
d
、x
类似于图形界面的 剪切操作 ——CTRL + X
- 命令
y
类似于图形界面的 复制操作 ——CTRL + C
- 命令
p
类似于图形界面的 粘贴操作 ——CTRL + V
vi
中的 文本缓冲区同样只有一个,如果后续做过 复制、剪切 操作,之前缓冲区中的内容会被替换
注意
vi
中的 文本缓冲区 和系统的 剪贴板 不是同一个- 所以在其他软件中使用
CTRL + C
复制的内容,不能在vi
中通过P
命令粘贴 - 可以在 编辑模式 下使用 鼠标右键粘贴
R
命令可以进入 替换模式,替换完成后,按下ESC
可以回到 命令模式- 替换命令 的作用就是不用进入 编辑模式,对文件进行 轻量级的修改
关注
打赏
最近更新
- 深拷贝和浅拷贝的区别(重点)
- 【Vue】走进Vue框架世界
- 【云服务器】项目部署—搭建网站—vue电商后台管理系统
- 【React介绍】 一文带你深入React
- 【React】React组件实例的三大属性之state,props,refs(你学废了吗)
- 【脚手架VueCLI】从零开始,创建一个VUE项目
- 【React】深入理解React组件生命周期----图文详解(含代码)
- 【React】DOM的Diffing算法是什么?以及DOM中key的作用----经典面试题
- 【React】1_使用React脚手架创建项目步骤--------详解(含项目结构说明)
- 【React】2_如何使用react脚手架写一个简单的页面?