编辑器Vim基本模式和指令 –【Linux基础开发工具】

一、编辑器vim的键盘布局

编辑器Vim基本模式和指令 --【Linux基础开发工具】

二、Linux编辑器-vim的使用

vi和vim都是多模式编辑器,但vim是vi的升级版,不仅兼容vi的所有命令,还增加了许多新功能,如语法高亮和可视化操作。vim可以在终端、X Window、Mac OS和Windows上运行。我们将以vim为例进行讲解。

下图展示了HJKL作为方向键的历史原因(最初的键盘没有独立的方向键):

编辑器Vim基本模式和指令 --【Linux基础开发工具】

三、vim的基本概念

我们将介绍vim的三种模式(虽然有更多模式,但目前掌握这三种即可):命令模式(Command mode)、插入模式(Insert mode)和底行模式(Last line mode)。各模式的功能如下:

正常/普通/命令模式(Normal mode):控制屏幕光标的移动,删除字符、单词或行,复制和移动段落,并进入插入模式或底行模式。插入模式(Insert mode):只有在插入模式下才能输入文字,按「ESC」键可返回命令模式。这是我们最常用的编辑模式。末行模式(Last line mode):用于文件保存或退出、文件替换、查找字符串和列出行号等操作。在命令模式下,按「shift+:」即可进入该模式。要查看所有模式,打开vim,在底行模式输入 :help vim-modes。我这里共有12种模式:6种基本模式和6种附加模式。

编辑器Vim基本模式和指令 --【Linux基础开发工具】

四、vim的基本操作

进入vim,在系统提示符输入vim及文件名后,就进入vim的全屏编辑界面:

$ vim test.c

注意,进入vim后处于正常模式,需要切换到插入模式才能输入文字。将正常模式切换至插入模式:

输入 a:光标后移一位开始输入输入 i:在光标位置开始输入输入 o:在光标下方插入新行并开始输入

将插入模式切换至正常模式:

若处于插入模式,只能输入文字。如果发现输入错误,想用光标键回退删除,可以按「ESC」键返回正常模式再进行删除。当然,也可以直接删除。

将正常模式切换至末行模式:

按「shift + :」,即输入「:」

退出vim并保存文件,在正常模式下按「:」进入末行模式,例如:

:w(保存当前文件):wq(保存并退出vim):q!(不保存强制退出vim)

五、vim正常模式命令集

从正常模式切换到插入模式:

按「i」进入插入模式,从光标当前位置开始输入文件按「a」进入插入模式,从光标所在位置的下一个位置开始输入文字按「o」进入插入模式,插入新的一行,从行首开始输入文字

从插入模式切换回命令模式:

按「ESC」键

移动光标:

使用键盘上的光标键移动,但正规的vim使用小写字母「h」「j」「k」「l」分别控制光标左、下、上、右移动一格按「G」:移动到文章末尾按「$」:移动到光标所在行的行尾按「^」:移动到光标所在行的行首按「w」:光标跳到下个单词的开头按「e」:光标跳到下个单词的结尾按「b」:光标回到上个单词的开头按「#l」:光标移到该行的第#个位置,如:5l, 56l按「gg」:进入文本开头按「shift+g」:进入文本末尾按「ctrl+b」:屏幕往后移动一页按「ctrl+f」:屏幕往前移动一页按「ctrl+u」:屏幕往后移动半页按「ctrl+d」:屏幕往前移动半页

删除文字:

「x」:每按一次,删除光标所在位置的一个字符「#x」:例如,「6x」表示删除光标所在位置的后面(包括自己在内)6个字符「X」:大写的X,每按一次,删除光标所在位置的前一个字符「#X」:例如,「20X」表示删除光标所在位置的前20个字符「dd」:删除光标所在行「#dd」:从光标所在行开始删除#行

复制:

「yw」:将光标所在之处到单词结尾的字符复制到缓冲区「#yw」:复制#个单词到缓冲区「yy」:复制光标所在行到缓冲区「#yy」:例如,「6yy」表示复制从光标所在行往下数6行文字「p」:将缓冲区内的字符粘贴到光标所在位置。注意:所有与「y」有关的复制命令都必须与「p」配合才能完成复制与粘贴功能

替换:

「r」:替换光标所在处的字符「R」:替换光标所到之处的字符,直到按下「ESC」键为止

撤销上一次操作:

「u」:如果误执行一个命令,可以马上按下「u」回到上一个操作。按多次「u」可以执行多次撤销「ctrl+r」:撤销的恢复

更改:

「cw」:更改光标所在处的单词到单词结尾处「c#w」:例如,「c3w」表示更改3个单词

跳至指定的行:

AI图像编辑器 AI图像编辑器

使用文本提示编辑、变换和增强照片

AI图像编辑器 46 查看详情 AI图像编辑器 「ctrl+g」:列出光标所在行的行号「#G」:例如,「15G」表示移动光标至文章的第15行行首

六、vim末行模式命令集

在使用末行模式之前,请确保按「ESC」键确认已处于正常模式,然后按「:」进入末行模式。

列出行号:

「set nu」:输入「set nu」后,会在文件的每一行前面列出行号

跳到文件中的某一行:

「#」:在冒号后输入一个数字,再按回车键就会跳到该行了,如输入数字15,再回车,就会跳到文章的第15行

查找字符:

「/关键字」:先按「/」键,再输入想寻找的字符。如果第一次找到的关键字不是想要的,可以一直按「n」继续往后查找「?关键字」:先按「?」键,再输入想寻找的字符。如果第一次找到的关键字不是想要的,可以一直按「n」继续往前查找

问题:/?查找有什么区别?操作实验一下。

保存文件:

「w」:在冒号输入字母「w」就可以将文件保存起来

离开vim:

「q」:按「q」就是退出,如果无法离开vim,可以在「q」后跟一个「!」强制离开vim「wq」:一般建议离开时,搭配「w」一起使用,这样在退出的时候还可以保存文件

七、vim操作总结

三种模式:

正常模式插入模式底行模式

我们共有12种总模式,大家可以进一步研究。

vim操作:

打开,关闭,查看,查询,插入,删除,替换,撤销,复制等操作练习:当堂口头模式切换练习

八、简单vim配置【了解】

配置文件的位置在目录 /etc/ 下面,有个名为 vimrc 的文件,这是系统中公共的vim配置文件,对所有用户都有效。而在每个用户的主目录下,都可以自己建立私有的配置文件,命名为:.vimrc。例如,/root 目录下,通常已经存在一个 .vimrc 文件,如果不存在,则创建之。切换用户成为自己,执行 su,进入自己的主工作目录,执行 cd ~,打开自己目录下的 .vimrc 文件,执行 vim .vimrc

常用配置选项,用来测试设置语法高亮:

syntax on

显示行号:

set nu

设置缩进的空格数为4:

set shiftwidth=4

使用插件要配置好看的vim,原生的配置可能功能不全,可以选择安装插件来完善配置,保证用户是你要配置的用户,接下来:

安装TagList插件,下载 taglist_xx.zip,解压完成,将解压出来的 doc 的内容放到 ~/.vim/doc,将解压出来的 plugin 下的内容复制到 ~/.vim/plugin。在 ~/.vimrc 中添加:

let Tlist_Show_One_File=1let Tlist_Exit_OnlyWindow=1let Tlist_Use_Right_Window=1

安装文件浏览器和窗口管理器插件:WinManager,下载 winmanager.zip,2.X版本以上的解压 winmanager.zip,将解压出来的 doc 的内容放到 ~/.vim/doc,将解压出来的 plugin 下的内容复制到 ~/.vim/plugin。在 ~/.vimrc 中添加:

let g:winManagerWindowLayout='FileExplorer|TagList'nmap wm :WMToggle

然后重启vim,打开 ~/XXX.c~/XXX.cpp,在正常状态下输入 “wm”,你将看到界面效果。更具体移步:点我,其他手册,请执行 vimtutor 命令。

参考资料:

Vim从入门到牛逼(Vim from zero to hero)

九、关于vim超级配置

在GitHub/Gitee上搜索vim配置,Ubuntu可以搜索vim plus,也可以直接点击。

以上就是编辑器Vim基本模式和指令 –【Linux基础开发工具】的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/513342.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月9日 01:57:11
下一篇 2025年11月9日 01:58:23

相关推荐

  • CSS元素设置em和transition后,为何载入页面无放大效果?

    css元素设置em和transition后,为何载入无放大效果 很多开发者在设置了em和transition后,却发现元素载入页面时无放大效果。本文将解答这一问题。 原问题:在视频演示中,将元素设置如下,载入页面会有放大效果。然而,在个人尝试中,并未出现该效果。这是由于macos和windows系统…

    2025年12月24日
    200
  • 如何模拟Windows 10 设置界面中的鼠标悬浮放大效果?

    win10设置界面的鼠标移动显示周边的样式(探照灯效果)的实现方式 在windows设置界面的鼠标悬浮效果中,光标周围会显示一个放大区域。在前端开发中,可以通过多种方式实现类似的效果。 使用css 使用css的transform和box-shadow属性。通过将transform: scale(1.…

    2025年12月24日
    200
  • 如何用HTML/JS实现Windows 10设置界面鼠标移动探照灯效果?

    Win10设置界面中的鼠标移动探照灯效果实现指南 想要在前端开发中实现类似于Windows 10设置界面的鼠标移动探照灯效果,有两种解决方案:CSS 和 HTML/JS 组合。 CSS 实现 不幸的是,仅使用CSS无法完全实现该效果。 立即学习“前端免费学习笔记(深入)”; HTML/JS 实现 要…

    2025年12月24日
    000
  • 如何用前端实现 Windows 10 设置界面的鼠标移动探照灯效果?

    如何在前端实现 Windows 10 设置界面中的鼠标移动探照灯效果 想要在前端开发中实现 Windows 10 设置界面中类似的鼠标移动探照灯效果,可以通过以下途径: CSS 解决方案 DEMO 1: Windows 10 网格悬停效果:https://codepen.io/tr4553r7/pe…

    2025年12月24日
    000
  • 如何用前端技术实现Windows 10 设置界面鼠标移动时的探照灯效果?

    探索在前端中实现 Windows 10 设置界面鼠标移动时的探照灯效果 在前端开发中,鼠标悬停在元素上时需要呈现类似于 Windows 10 设置界面所展示的探照灯效果,这其中涉及到了元素外围显示光圈效果的技术实现。 CSS 实现 虽然 CSS 无法直接实现探照灯效果,但可以通过以下技巧营造出类似效…

    2025年12月24日
    000
  • 为什么自定义样式表在 Safari 中访问百度页面时无法生效?

    自定义样式表在 safari 中失效的原因 用户尝试在 safari 偏好设置中添加自定义样式表,代码如下: body { background-image: url(“/users/luxury/desktop/wallhaven-o5762l.png”) !important;} 测试后发现,在…

    2025年12月24日
    000
  • HTML、CSS 和 JavaScript 中的简单侧边栏菜单

    构建一个简单的侧边栏菜单是一个很好的主意,它可以为您的网站添加有价值的功能和令人惊叹的外观。 侧边栏菜单对于客户找到不同项目的方式很有用,而不会让他们觉得自己有太多选择,从而创造了简单性和秩序。 今天,我将分享一个简单的 HTML、CSS 和 JavaScript 源代码来创建一个简单的侧边栏菜单。…

    2025年12月24日
    200
  • 前端代码辅助工具:如何选择最可靠的AI工具?

    前端代码辅助工具:可靠性探讨 对于前端工程师来说,在HTML、CSS和JavaScript开发中借助AI工具是司空见惯的事情。然而,并非所有工具都能提供同等的可靠性。 个性化需求 关于哪个AI工具最可靠,这个问题没有一刀切的答案。每个人的使用习惯和项目需求各不相同。以下是一些影响选择的重要因素: 立…

    2025年12月24日
    300
  • 带有 HTML、CSS 和 JavaScript 工具提示的响应式侧边导航栏

    响应式侧边导航栏不仅有助于改善网站的导航,还可以解决整齐放置链接的问题,从而增强用户体验。通过使用工具提示,可以让用户了解每个链接的功能,包括设计紧凑的情况。 在本教程中,我将解释使用 html、css、javascript 创建带有工具提示的响应式侧栏导航的完整代码。 对于那些一直想要一个干净、简…

    2025年12月24日
    000
  • 如何在网页 F12 调试中查看鼠标悬停时才出现的 DOM 元素?

    如何在网页 f12 调试中查看鼠标悬停时才出现的 dom 元素? 在 f12 调试模式下,鼠标悬停时才出现的 dom 元素无法通过直接选择查看。解决方法根据显示原理的不同而有所区别: 1. css 控制的元素 强制开启悬停状态:在 firefox 浏览器中,可以通过在开发者工具中手动开启选中元素的 …

    2025年12月24日 好文分享
    100
  • 布局 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在这里查看视觉效果: 固定导航 – 布局 – codesandbox两列 – 布局 – codesandbox三列 – 布局 – codesandbox圣杯 &#8…

    2025年12月24日
    000
  • 隐藏元素 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看隐藏元素的视觉效果 – codesandbox 隐藏元素 hiding elements hiding elements hiding elements hiding elements hiding element…

    2025年12月24日
    400
  • 居中 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看垂直中心 – codesandbox 和水平中心的视觉效果。 通过 css 居中 垂直居中 centering centering centering centering centering centering立即…

    2025年12月24日 好文分享
    300
  • 如何在 Laravel 框架中轻松集成微信支付和支付宝支付?

    如何用 laravel 框架集成微信支付和支付宝支付 问题:如何在 laravel 框架中集成微信支付和支付宝支付? 回答: 建议使用 easywechat 的 laravel 版,easywechat 是一个由腾讯工程师开发的高质量微信开放平台 sdk,已被广泛地应用于许多 laravel 项目中…

    2025年12月24日
    000
  • 如何在移动端实现子 div 在父 div 内任意滑动查看?

    如何在移动端中实现让子 div 在父 div 内任意滑动查看 在移动端开发中,有时我们需要让子 div 在父 div 内任意滑动查看。然而,使用滚动条无法实现负值移动,因此需要采用其他方法。 解决方案: 使用绝对布局(absolute)或相对布局(relative):将子 div 设置为绝对或相对定…

    2025年12月24日
    000
  • 移动端嵌套 DIV 中子 DIV 如何水平滑动?

    移动端嵌套 DIV 中子 DIV 滑动 在移动端开发中,遇到这样的问题:当子 DIV 的高度小于父 DIV 时,无法在父 DIV 中水平滚动子 DIV。 无限画布 要实现子 DIV 在父 DIV 中任意滑动,需要创建一个无限画布。使用滚动无法达到负值,因此需要使用其他方法。 相对定位 一种方法是将子…

    2025年12月24日
    000
  • 移动端项目中,如何消除rem字体大小计算带来的CSS扭曲?

    移动端项目中消除rem字体大小计算带来的css扭曲 在移动端项目中,使用rem计算根节点字体大小可以实现自适应布局。但是,此方法可能会导致页面打开时出现css扭曲,这是因为页面内容在根节点字体大小赋值后重新渲染造成的。 解决方案: 要避免这种情况,将计算根节点字体大小的js脚本移动到页面的最前面,即…

    2025年12月24日
    000
  • Nuxt 移动端项目中 rem 计算导致 CSS 变形,如何解决?

    Nuxt 移动端项目中解决 rem 计算导致 CSS 变形 在 Nuxt 移动端项目中使用 rem 计算根节点字体大小时,可能会遇到一个问题:页面内容在字体大小发生变化时会重绘,导致 CSS 变形。 解决方案: 可将计算根节点字体大小的 JS 代码块置于页面最前端的 标签内,确保在其他资源加载之前执…

    2025年12月24日
    200
  • Nuxt 移动端项目使用 rem 计算字体大小导致页面变形,如何解决?

    rem 计算导致移动端页面变形的解决方法 在 nuxt 移动端项目中使用 rem 计算根节点字体大小时,页面会发生内容重绘,导致页面打开时出现样式变形。如何避免这种现象? 解决方案: 移动根节点字体大小计算代码到页面顶部,即 head 中。 原理: flexível.js 也遇到了类似问题,它的解决…

    2025年12月24日
    000
  • 形状 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看 codesandbox 的视觉效果。 通过css绘制各种形状 如何在 css 中绘制正方形、梯形、三角形、异形三角形、扇形、圆形、半圆、固定宽高比、0.5px 线? shapes 0.5px line .square { w…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信