建立自己的键盘栈(shortcutkeyStack)
建立自己的键盘栈(shortcutkeyStack)
作为一名开发者, 快捷键是必不可少的, 并且各种开发工具都有提供快捷键. 但是各种工具(IDE,编辑器)因为历史或者其他不可抗原因(比如键盘的布局就是一个很不符合人体功能学的东西), 导致了目前的会计诶按布局.
所以快捷键的主流习惯, 有 Eclipse 流, 有 Intelligent (webStorm, phoStorm, idea)流, 有 vim 流, 有sublime流. 现在 vscode 大热, 也就有了 vscode 流. 每种快捷键都有自己的习惯. 如果更换编辑器的话, 又要费一门心思去了解快捷键(最起码我第一件事就是去熟悉这个东西)
但是我们可以建立自己的一套机制, 当然如果你熟悉eclipse, 可以将其他的IDE更改为 eclipse 布局. 可我要说的是: 比如一个复制行操作(复制所选择的行), 默认快捷键是 ctrl(command) + alt + up/down, 不得不使用两个手, 并且两个手掌都要进行位移. 这对于我们的码农来说是一个生产力的极大伤害.
所以, 我想每个人都应该有一个方便快捷可用的快捷键体系, 我这里列举出我自己的, 仅作为一个分享和交流.
之所以没有说vim的强大, 是因为vim需要太多记忆与熟悉体系, 很多对 linux 系统不是很熟悉的人会感觉头大, 并且也只是强大,并不是好用的强大
我使用的是mac系统, 所以其中的是command, 如果是windows, 非常建议改建, 将 windows功能键 更改为 ctrl 键, 具体方法只好百度了, 发现是很好改的. mac 下就推荐神器 Karabiner 了, 非常好用,非常强大
功能整理
作为程序员, 其实操作ide最常用的功能就那么几个, 我们需要把这几个最常用的功能放在我们最容易按到的键位(最好是左手操作), 方便使用也高效.
常用
- 浏览文件 command + r //非常顺手, 而且文件切换的时候经常会用到 vscode 默认 command+p, 我相信除非用右手, 否则一定是两个手. 如果你这个时候, 还在用着鼠标, 不得不切回来了.
浏览方法或者功能 command + t // 同上
- 复制行 command + shift + d // 这个很常用的功能, 但是 command + d 作为删除太常用了, 所以左手原则 + 好用的话, 就选择了这个
- 删除行 command + d // 不解释
跳转到最后编辑出 command + e //最常使用, 最容易触碰
- 回退 command + 2 //我回退使用的很多, 但是前进就很少了. 我一般会用最后编辑的地方就行前进, 因为前进是回退的反操作~
- command + 1 //代码提醒, 这个也是最常用的.
- command + 3 // 跳转到git的下一个不同. 协作很多, 提交要注意, 所以我每次提交都很小心的比对一下. 这个很常用.
- command + 4 // 跳转到下一处错误, 这个对于快速解决问题很好用
command + 5 // 合并当前区域, 没有展开, 展开去点击一下就可以了.
- ctrl + d //选择下一个与当前相同的
- 跳转到代码区块开头或者结尾 command + [/] //webstorm 比较强大, 可以支持, vscode 只有 toggle 的, 所以看自己喜好了
跳转到代码区块开头或者结尾并选择 shift + command + [/]
- 查看最近的文件 command + f3
查看最近的修改文件 command + f4
其他, 或者不常用?
- git 管理, 提交 ctrl + c // commit
- git 管理, 解决冲突 command + k + c
- git 管理, 查看文件历史 alt + h
基本上每个ide我都会更改成这个样子. 便于统一使用. 原则上是
好用, 好记 当然快捷键还有更多的设置.
建立自己的键盘栈(shortcutkeyStack)的更多相关文章
- Java虚拟机栈
Java Virtual Machine Stacks,线程私有,生命周期与线程相同,描述的是Java方法执行的内存模型:每一个方法执行的同时都会创建一个栈帧(Stack Frame),由于存储局部变 ...
- JavaScript变量——栈内存or堆内存
原文 http://blog.csdn.net/xdd19910505/article/details/41900693 堆和栈这两个字我们已经接触多很多次,那么具体是什么存在栈中什么存在堆中呢?就 ...
- 谈谈arm下的函数栈
引言 这篇文章简要说说函数是怎么传入参数的,我们都知道,当一个函数调用使用少量参数(ARM上是少于等于4个)时,参数是通过寄存器进行传值(ARM上是通过r0,r1,r2,r3),而当参数多于4个时,会 ...
- 递归转手工栈处理的一般式[C语言]
是任意形式的递归,是化解的一般式. 主题所谓的“递归调用化解为栈处理”,意思是,将递归函数调用化解为“一个由stack_push stack_pop stack_top等函数调用组成的循环式子”.这里 ...
- C函数调用与栈
这篇blog试图说明这么一个问题,当一个c函数被调用时,一个栈帧(stack frame)是如何被建立,又如何被消除的.这些细节跟操作系统平台及编译器的实现有关,下面的描述是针对运行在Linux的gc ...
- C语言数据结构----栈的定义及实现
本节主要说的是数据结构中的栈的基本定义和实现的方式,其中实现的方式采用的是复用顺序表和单向链表的方式. 一.栈的基本定义 1.栈是一种特殊的线性表,只能从固定的方向进出,而且栈进出的基本原则是:先进栈 ...
- js 中的栈和堆
js中的栈与堆的讲解/基本数据类型与引用类型的讲解 前言:1. 学习前端,入门简单,想学好确实是一件很困难的事情,东西多而且杂,版本快速迭代,产品框架层出不穷. 2. 前端学习成本确实很高,需要不断的 ...
- js中的栈、堆、队列、内存空间
栈(stack) .堆(heap). 队列(queue)是js的三种数据结构. 栈(stack) 栈的特点是"LIFO,即后进先出(Last in, first out)".数据存 ...
- python的数据结构之栈
栈是一种特殊的列表,栈内的元素只能通过列表的一端访问,这一端称为栈顶.栈被称为一种后入先出(LIFO,last-in-first-out)的数据结构. 由于栈具有后入先出的特点,所以任何不在栈顶的元素 ...
随机推荐
- Jupyter交互式工具安装使用
Jupyter交互式工具安装使用 Jupyter Notebook(此前被称为IPython notebook)是一个交互式笔记本,支持运行 40 多种编程语言. 文档:https://jupyter ...
- c# 异步( Async ) 不是多线程
c# 异步( Async ) 不是多线程 误解 async 在调试 xxxxAsync() 方法的时候,常常会看到调试器界面中会多出一些线程,直觉上误认为 Async 冠名的函数是多线程. 对于 ...
- 作为消费者访问提供者提供的功能(eureka的铺垫案例)
1. 实体类.提供者的创建如本随笔者的Euraka适合初学者的简单小demo中有所展示 2. 创建子工程作为消费者 (1) 添加依赖:切记引入实体类的依赖 <dependencies> & ...
- 提高QPS
常用方案 1.异步化+MQ 即非阻塞,化繁为简,拿到你需要处理的资源后尽快回复.适用于事务处理场景,且无需对上游返回数据场景. 2.无锁设计 本质上是要降低锁冲突,基于数据版本的乐观锁 有效的减少了互 ...
- 【转载】Extjs设置Ajax请求的超时时间timeout
在Extjs中的Ajax请求中,Ext.Ajax.request 默认超时时间是30秒,有时候我们有比较耗时的操作需要设置更长时间,此时我们就需要修改Ext.Ajax.Requset的超时时间为更长, ...
- flutter报错--ProcessException: Process... gradlew.bat ...exited abnormally
在 VScode 中 debug flutter 是遇到如下问题: ProcessException: Process "G:\demo\flutter\hello_word\android ...
- MySQL数据库使用时注意事项
MySQL数据库使用时注意事项 建表的角度上 1.合理安排表关系 2.尽量把固定长度的字段放在前面 3.尽量使用char 代替varchar 4.分表:水平分和垂直分 在使用sql语句的时候 1.尽量 ...
- Fatal error: Uncaught Error: Call to a member function bind_param() on boolean
1.2019年10月22日 PHP写mysqli 预编译查询的时候报错. Fatal error: Uncaught Error: Call to a member function bind_par ...
- robot framework笔记(二):在RF中自定义chrome启动参数
(一)在RF中自定义chrome启动参数 这里主要是实现下面2个功能 1.禁用chrome正受自动测试软件控制的提示 2.设置默认的下载路径(一些导出.下载类的功能,将文件下载到指定路径下) 自定义一 ...
- 【MySQL】SQL语句基础
一.操作数据库 1.1 创建数据库 1.2 查看数据库 1.3 修改数据库 1.4 删除数据库 1.5 选择数据库 二.操作表 2.1 创建表 2.2 查看表 2.3 修改表 2.4 删除表 三.操作 ...