tab选项卡

回忆上次

  • 上次有三种批量替换,分别是

    • :windo
    • :bufdo
    • :argdo
    • 执行的{cmd}可以用按顺序增加
  • 分别对应的

    • windows 窗口
    • buffers 缓存文件
    • arguments 参数文件
  • 各有各自的列表、切换、删除增加的方式
  • 以什么开始、结束的模式

    • zs
    • ze
  • 关于 window 窗口容器

    • 我们切得越细
    • 可用的范围越小
    • 总共 80*24 的屏幕资源很快就用完了
  • 我又想多线程访问
  • 又想有足够的屏幕来编辑
  • 那怎么办呢?
  • 除了window之外还有容器吗?

tabs选项卡

  • 我们发现用windows的方式瓜分屏幕
  • 很快就有了尽头
  • 因为window之间彼此不覆盖
  • 所以80*24个字符的空间很快被填满
  • 有什么方法建立可覆盖的空间么?

    • 还真有那就是tab选项卡
  • 在terminal中运行vi ooo
  • :tabnew oeasy.txt

    • 新建一个tab选项页
    • tab里面有一个window
    • window里面一个buffer
    • buffer内容是oeasy.txt
  • 可以用:tabs查看当前有几个tab里面分别打开着什么
  • :tabnew h gt

    • 在新的tab选项卡里面查询gt命令
  • :tabnew ./oeasy.java

    • 在新的tab选项卡里面打开当前目录下的oeasy.java
  • :tabnew ~/.vimrc

    • 在新的tab选项卡里面打开~/.vimrc

切换

  • tabs切换

    • :tabnext - 下一个tab - 快捷键gt
    • :tabprevious - 上一个tab - 快捷键gT
    • :tablast - 最后tab
    • :tabfirst - 最初tab
  • :tabclose 关闭当前tab
  • :tabonly 只保留当前的tab

tab中再分window

  • 给第一个tab水平方向分成两个window

    • :split
    • 分别打开o2o3
  • 给第二个tab先水平

    • 再垂直分成三个window
    • :split:vsplit
  • 观察 :tabs

  • 当前 window

    • 就是tab 页 1o3这个window
    • 前面有大于号表明这是当前current窗口window
  • 当然也可以

    • :wa
    • :wqa
    • :qa
    • :qa!

选择

  • 先选择 tab选项卡

    • :tabnext - 下一个tab
    • :tabprevious - 上一个tab
    • :tablast - 最后tab
    • :tabfirst - 最初tab
  • 再选择window窗口

    • ctrl-w再k切换到当前窗口上面的窗口
    • ctrl->w再j切换到当前窗口下面的窗口
    • ctrl-w再h切换到当前窗口左面的窗口
    • ctrl-w再l切换到当前窗口右面的窗口
  • 选好了位置之后可以选择 buffer缓存

    • :b1 把当前窗口位置显示 buffer1缓存内容
  • 窗口的隐藏和全屏

    • :hid[e] 可以在当前的 tab选项卡 隐藏当前窗口
    • 隐藏的 window窗口 中 buffer缓存 不保存
    • 除非设置了autowrite
    • :on[ly] 可以在当前的 tab选项卡
    • 全屏显示当前 window窗口
    • 其他的窗口都进入 :hide 状态

跳转到指定的选项卡tab

  • tab1跳转到第1个tab
  • tab2跳转到第2个tab
  • tab3跳转到第3个tab
  • tab5跳转到第5个tab

移动选项卡位置

  • :-tabmove 当前选项卡左移动
  • :+tabmove 当前选项卡右移动
  • :0tabmove 当前选项卡移动到最左边
  • :tabmove 0 当前选项卡移动到最左边
  • 这样的选项卡很方便打开一个帮助

    • :tab help gt

按照选项卡打开文件

  • vim -p file1.js file2.js file3.js
  • 对比原来按照window打开文件

    • vim -o file1.js file2.js file3.js
    • vim -O file1.js file2.js file3.js

  • :tabn:tabp可以切换标签页
  • 更快速的方法是gtgT1gt

容器汇总

  • vim命令打开的参数对应一个列表 - arguments参数列表

    • 列表 - :args
    • 添加 - :arga
    • 删除 - :argd
    • 执行命令 - :argdo
  • 打开的文件缓存对应一个列表 - buffers缓存列表

    • 列表 - :ls
    • 添加 - :e .
    • 切换 - :b1
    • 关闭 - :bd
    • 执行命令 - :bufdo
  • tab选项卡对应一个列表 - tabs选项卡列表

    • 列表 - :tabs
    • 打开 - :tabnew
    • 切换 - gt、gT
    • 关闭 - :tabc
    • 执行命令 - :tabdo
  • tab选项卡中的窗口对应一个列表 - windows窗口列表

    • 列表 - :sp:vsp
    • 打开 - ctrl+w后加hjkl
    • 关闭 - :q
    • 执行命令 - :windo

总结

oeasy教您玩转vim - 68 - # 标签页tab的更多相关文章

  1. oeasy教您玩转vim - 56 - # 字符可视化模式

    ​ 可视化编辑 回忆上节课内容 我们学习了关于模式匹配中使用参数 单个参数 :%s/<h2>\(.*\)</h2>/ - \1/g 多个参数 :%s/<img src=\ ...

  2. oeasy教您玩转vim - 57 - # 行可视化

    ​ 可视化编辑 回忆上节课内容 上次我们了解到可视模式 其实可视化对应三种子模式 字符可视模式 v 行可视模式 大写V 块可视模式ctrl+v 我们先来了解字符可视化模式 快捷键 v 可配合各种mot ...

  3. oeasy教您玩转vim - 53 - # 批量替换

    查找细节 回忆上节课内容 我们温习了关于搜索的相关内容 /正向,?反向 n保持方向,N改变方向 可以设置 是否忽略大写小写 是否从头开始查找 是否高亮显示 还有一些正则表达式的使用方法 行头行尾 ^$ ...

  4. EasyUI创建异步树形菜单和动态添加标签页tab

    创建异步树形菜单 创建树形菜单的ul标签 <ul class="easyui-tree" id="treeMenu"> </ul> 写j ...

  5. Bootstrap标签页(Tab)插件

    标签页(Tab)在Bootstrap导航元素一章中简介过,通过结合一些data属性,您可以轻松地创建一些标签页界面.通过这个插件您可以把内容放置在标签页或胶囊式标签页甚至是下拉菜单标签页中. 用法 您 ...

  6. 标签页tab.js 在栏目之间切换,局部变化

    1.在使用bootstrap 中,我们会用到在栏目之间切换,来刷新页面的局部,可以使用下面的方法 <link rel="stylesheet" href="http ...

  7. 在QMainWindow中利用多个QDockWidget构成标签页tab(原创)

    功能描述: 在QMainWindow下,使用多个QDockWidget构成可切换,可拖动,可关闭的标签页:标签页的切换由相关联的QAction触发. 实现效果: 代码如下: QDockWidget * ...

  8. 解决Bootstrap 标签页(Tab)插件切换echarts不显示问题

    1.参考连接:https://blog.csdn.net/qq_24313955/article/details/78363981 问题描述:在echarts跟bootstrap选项卡整合的时候,默认 ...

  9. bootstrap 标签页tab切换js(含报错原因)

    booststrap 标签页的tab切换,相信大家已经都很熟悉了,在boot官网示例以及其他网站已经很多罗列相关代码的了,这里就不赘述了.这里主要贴下让boot标签页默认显示哪个标签页的js. 主要留 ...

  10. Bootstrap标签页(Tab)插件事件

    事件 下表列出了标签页(Tab)插件中要用到的事件.这些事件可在函数中当钩子使用. 事件 描述 实例 show.bs.tab 该事件在标签页显示时触发,但是必须在新标签页被显示之前.分别使用 even ...

随机推荐

  1. layui-框架学习小总结

    主要6点: 1.导航栏变成了类似tab的页签,支持关闭,点击刷新. 2.左侧菜单树可隐藏. 3.树的搜索. 4.表格的新增行,并保存到后台. 5.表格 加载 下拉框,并赋值,选择了值后把值同步到表格对 ...

  2. 为datagridview添加自定义按钮

    先上图: 我是直接网上搜得代码,不是本人写得.下面说说大体思路,继承DataGridViewButtonCell类实现自定义类比如这个:DataGridViewDetailButtonCell 里面, ...

  3. vue-cli 中使用 Axios

    安装 axios: 1 npm install axios --save-dev 接着在src目录下创建一个http.js脚本中,导入axios并通过create方法实例化一个http请求对象,这样我 ...

  4. Android 13 - Media框架(9)- NuPlayer::Decoder

    关注公众号免费阅读全文,进入音视频开发技术分享群! 这一节我们将了解 NuPlayer::Decoder,学习如何将 MediaCodec wrap 成一个强大的 Decoder.这一节会提前讲到 M ...

  5. C# JObject.Add方法代码示例

    本文整理汇总了C#中Newtonsoft.Json.Linq.JObject.Add方法的典型用法代码示例.如果您正苦于以下问题:C# JObject.Add方法的具体用法?C# JObject.Ad ...

  6. QShop商城-快速开始-uni-app小程序

    QShop商城-快速开始-uni-app小程序 工具准备 HBuilderX 此项目为UniApp开发,开发工具为HBuilderX,下载地址: https://hx.dcloud.net.cn/Tu ...

  7. itest work(爱测试) 开源一站式接口测试&敏捷测试工作站 9.0.5. Rc4

    (一)itest work 简介 itest work (爱测试)  一站式工作站让测试变得简单.敏捷,"好用.好看,好敏捷" ,是itest wrok 追求的目标.itest w ...

  8. itest(爱测试)开源接口测试&敏捷测试&极简项目管理 6.6.6 发布,新增接口mock

    (一)itest 简介及更新说明 itest 开源敏捷测试管理,testOps 践行者,极简的任务管理,测试管理,缺陷管理,测试环境管理,接口测试,接口Mock 6合1,又有丰富的统计分析.可按测试包 ...

  9. kettle从入门到精通 第二十八课 初识kettle-job

    1.前面我们一起学习了,很多转换的知识,转换为批量的开发做铺垫,今天我们一起来学习下kettle job的知识. kettle job 常用的步骤如下图,有Start.转换.作业.成功等步骤. 2.下 ...

  10. docker on windows v19 红色启动不了

    遇到: error during connect: Get http://%2F%2F.%2Fpipe%2Fdocker_engine/v1.40/containers/json: open //./ ...