这里是HN上的讨论:
GitHub's new text editor leaked on Twitter
这里是github page:
Atom · GitHub 好多repo啊
我不知道有没有知友了解更多情况?我很期待。
今天拿到邀请试用了一会儿,可以明确的说跟 Sublime 没有关系。Sublime 是原生界面,脚本用的是 python;Atom 应该是基于 Chromium Embedded Framework,基本上就是个 web app,源码都是 CoffeeScript 写的,连界面都可以用 CSS 来自定义。
除了基本的操作和界面外,和 Sublime 最大的差别在于扩展性。Atom 非常强调模块化,很多默认功能也都是开源的模块。自带友好的模块管理界面,相比之下 Sublime 需要自己手动安装,或是依赖第三方的 package control。Atom 的扩展也是用 JS 或者 Coffee 在 Node + webkit 的环境下开发,并且可以使用 npm 的包,这对于前端和 Node 开发者是很有诱惑力的,需要的话完全可以把 Atom 打造成一个 IDE。
一个明显的缺点是,启动和开文件速度明显不如 Sublime 3。
GitHub 创始人 Mojombo 在论坛上说 Atom 正式发布以后是要收费的,内核将会是以限制性的协议开源,可以看了学习,但是不能拿来商用。其他所有官方模块都是 MIT 协议开源。从策略上来讲,GitHub 以后肯定会通过官方模块把 Atom 和 GitHub 进行深度整合。收费我估计不会贵到哪里去,说到底让开发者因为 Atom 而用 GitHub 用得爽,进一步加强用户黏度才是目的吧。这和 Google 做浏览器是一个道理。
---
补充一些技术实现上的细节:打开 Package Content 看了下,可以看到内部的由 CoffeeScript 编译过来的 JavaScript。内部的一些模块在 GitHub 上也能找到源码。核心的两个库,一个是界面库 Space Pen ( https://github.com/atom/space-pen ),自带创建 DOM 的 DSL,并继承自 jQuery 原型,可以看做加强版的 Backbone.View。另一个库是 Theorist ( https://github.com/atom/theorist ),一个基于事件的模型库,类似 Backbone.Model + Backbone.Collection。内部用了大量的 emitter 和 subscriber 模式。总的来说,代码很清晰,模块化做得非常好,非常值得做 SPA 的前端学习。
刚打开的时候,一股Sublime Text的气息铺面而来. 随后的使用中也发现如果你是ST的熟练使用者,接触Atom基本可以无缝切换,内置ctrl-p, plugin management;
但是使用了一会,发现实在还是很弱,插件还很少,基本上对编程语言的支持只有语法高亮和snippets. 由于我主要使用这类编辑器来写c, go和python,目前看来对这几个语言的支持都不太好,首先没有ctags插件,没有支持gocode补全的插件, 也没有python的代码补全。基本只有高亮。不过比较欣慰的是至少还有vim mode...
不过我还是很看好atom未来的发展的,从plugin在客户端里的展示的位置看来,atom将plugin放在主要的地位,而且可以使用coffee script(js)开发插件降低了插件的开发成本,应该会很受node社区的欢迎。
放几个图欣赏一下:
我用着vim mode,居然搜不出vim.... orz
看着很美,但是没有自动补全啊!魂淡!
插件的使用说明倒是蛮直观的
总结一句话,对我来说就是个好看的羸弱的ST,长期来说看好。期待可以从ST切换过去的一天。
Atom 唯一的槽点就是“卡”,不过那是去年的情况了,1.0后性能数次大提升,比起sublime/vsc之类虽不算流畅,但同时编辑20个数千行的文件没有压力。如今让人感觉慢的地方主要是启动loading(也大大短于eclipse, idea),使用时并没察觉它比其他编辑器慢再哪。而文本编辑器的快慢,更重要的是“让你工作更快更有效率”。下面说说为何 Atom比其他更有效率:
兼容VIM模式
这无疑团结了一大班 Vim过来的用户,Sublime虽然也有VIM模式,但是Sublime在 mac下面的vim模式有bug,我习惯用 hjkl来移动光标,sublime再mac下hjkl移动有问题,且我习惯CTRL_[来返回NORMAL,手指不离开主键盘区,而sublime的vim模式只支持ESC返回,加上其作者经常神秘消失,最稳定的2.x版本已三年没有更新,这些问题一直得不到修正。
由于Atom的定制程度直追 Vim/Emacs,它的vim模式能够使用插件来实现,而不像sublime必须builtin,Atom的VIM模式除了官方实现外还有很多用户实现,各有所长,你不喜欢可以换,Sublime就傻逼了,觉得builtin的不行,你就没办法了,而且作者不更新你也没办法。
Atom里的Vim模式并不是强制的,你可以用也可以不用,这样入门用户也不会觉得困难,但是如果你用惯Vim的话,使用Vim模式可以取得更好的效率,我觉得Vim/Atom-VimMode能够提升效率的地方有以下三方面:
1. 手指不离开主键盘区:
所有功能皆能在主键盘区完成,不用去按方向键,不用把手挪去按Home/End,更不用动鼠标。就像咏春中强调中线理论,认为一切动作围绕中轴线开展,守护自己中轴线的同时攻击别人的中轴线。Vim/Atom-VimMode中,双手不但从不离开主键盘,并且八根手指随时守护再HOME位(ASDF, JKL;)有动作就移动,然后马上归位。
2. 细粒度微操作:
星际/dota玩的好,微操基本功,微操又快又精确,Vim/Atom-VimMode一样,比如:
if (xxxx) {
}
使用o直接再下一行插入,避免 END/回车
使用I再行首插入,避免移动半天光标。
向前/后移动一个单词到单词头、尾。
快速更改当前单词,用/来快速搜索移动光标。
dd+p来快速移动代码块,取代shift+方向键半天。
shift-j 来两行合并成一行,代替 HOME, back 若干次。
。。。
你再编辑代码的时候,90%的情况可以直接一步完成,这就叫细粒度微操,而且整个过程手都不需要离开主键盘,不像传统编辑器那样,若干笨重的操作组合再一起,操作不够细步骤多的同时手还要再:主键盘区,方向键区,扩展键区 来回移动,效率奇低。而Vim/Atom-VimMode下,手指随时守护在home区(ASDF JKL;),所有微操都是围绕HOME区进行,不会移动到任何主键盘以外的区域,更别说用鼠标、触摸板。
3. 批量操作:
比如要给下面代码每行后面加一个分号:
var x = 1
var y = 2
var z = 3
console.log('result is ' + (x + y + z).toString())
第一行:A;<ESC>
后面所有行:J.
超级爽快的操作,这样的操作还很多,你还可以单条命令对一万行代码重复上述步骤,或者把c代码拷贝到go里面先一句话把所有分号给删除了。Vim下面的名言:绝不重复。
总之如果你熟悉 VIM模式,用 Atom能感到完全自由的方式,随心所欲的书写代码,而不是被书写这件事情费脑筋,解放大脑完全用于思考而不用于打字。但是同时对不习惯VIM的人照样友好,或者对想使用VIM的便利却又痛恨VIM这个软件的简陋的人带来了福音。
脊椎记忆
“同样动作重复300次,肌肉就会有记忆,而一个动作重复600次,脊椎就会有记忆”
-- 李小龙
编辑器就是关于脊柱记忆的东西,所以多投入一些时间去了解你使用的编辑器,掌握他们的各种快捷操作和高级功能是一个能让你事半功倍的好主意。
格斗游戏玩的好的人有很多,下等高手靠熟练,中等高手靠反应,上等高手靠意识。更熟练的掌握你的编辑器,让更多日常工作固化成记忆记录再你的脊椎上,使用的时候,脊椎这枚协处理器就能完成代码编写,一个操作,刚一想到,脊椎就自动执行出来了,小脑腾出空间来组织判断,大脑腾出空间来思考更重要的东西,就像你走路,你不用思考迈腿那么自然,别人一拳过来,你潜意识一动,一连串动作就出去了,一只飞蛾飞过来,你潜意识的闭上眼睛保护眼部,这就是脊椎记忆,如果还要经过大脑绕一圈,反应慢不说,大脑这颗cpu都用在这些琐事上了,思考的时间自然少了不少。
所以从内到外的了解你的编辑器,并且熟练掌握他们,是对你提高工作效率的最佳投资,Atom的全平台支持,开放源代码,深度可定制等三个特点,比起其他闭源的,平台支持不全的,扩展少的编辑器来说能让你有不同层面的了解机会,同时为你提供足够的空间。
深度可定制系统
Vim/Emacs的精髓在于:“可以调教”,本来不顺手的东西,只要容易调教,假以时日,都会慢慢变得越来越顺手,越来越“懂你”,越来越“贴心”,以至于后面大家都离不开它了。而 Atom 也同样是一款容易被你调教的编辑器。先前给vim写过插件,给sublime写过插件,如今给Atom写过插件,横向对比下来,几个结论:
插件能做事情多少:Atom > Vim >> sublime
插件开发学习门槛:Vim > Atom > sublime
插件开发文档丰富:Atom > sublime >> Vim
Atom 的定制化程度远远高过sublime之类(不用实际看法,看看双方开发文档即可),直追 Vim / Emacs,sublime的大部分定制无外乎改改json,插件能做的事情相当有限。
Atom 的定制化系统主要有三方面:
1. 细致:
设计之初就考虑的事情,方方面面都能定制,见官方文档,以及插件:vim-mode,minimap (稍微了解下这两个类似的功能再 Atom 和 sublime的实现就能知道 sublime被甩了多少条街了)。可以细粒度的控制编辑器内所有行为,小到移动一下光标,删除当前一个字符,大到打开一个面板,比如 “core:more-up” 可以向上移动一行光标,“window:focus-pane-on-left” 可以把焦点设置到左边的面板,atom内核和大量第一方第三方packages 都是以命令的方式把基础功能提供出来,你可以随意互相调用或者设置热键。
除去命令外的API层面,几乎每个部件每个像素点都可控,比如这样的插件你永远无法再 Vim / Emacs / Sublime 下面见得到:activate-power-mode。
2. 直观:
由于使用 javascript/coffee进行开发,但 javascript/coffee是属于即便你没写过他们,读都能读得懂,VimScript就不一样了,虽然也能做相同的事情,但实话实说,晦涩难写,比如我要取得当前文件的路径和文件名,在 VimScript里面需要这么写:
let l:path = expand('%:p:h')
let l:name = expand('%:t:r')
或者
let l:name = expand('%<')
var fullpath =atom.workspace.getActiveTextEditor().getPath();
var filename = path.basename(fullpath);
var filepath = path.dirname(fullpath);
结论是很清晰的,Atom的 javascript开发插件更简单直观,即便没文档,看别人怎么写的自己也会了,同时灵活性大大高于VmScript,各种事件处理回调,javascript天生擅长做这些事情,还有第二行,第三行,我们用到了 node.js 的 path模块,进行文件路径切割。这样的写法,再VimScript 里面基本是无法想象的。
Vim是强大,但是毕竟是30年前的东西了,即便最熟练的 Vimer 也都承认 VimScript 的晦涩难懂,阻碍了很多人为其开发插件。而给Atom开发插件,只需要掌握javascript,掌握 javascript的人很多,学习了javascript你也可以用在很多地方。不像VimScript那样只能用在Vim里面,而正因为其晦涩,Vim新版本开始支持内嵌 python的写法:
python << EOF
import random
print random.randint(0,10)
EOF
VimScript中 Python等动态的支持正是说明其开发维护者也承认 VimScript本身的古老,对比现代编程语言已经有些格格不入了,缺乏强大的描述能力,难以构建复杂的功能模块,才会去支持Python内嵌这样的写法。可大量的工作还是需要再Python之外完成,同时,并非所有平台自带的Vim都支持python,除了mac外,所有debian / ubuntu 发行版自带的Vim都不支持 Python。导致你想写一个通用的扩展还得判断下是否 has('python') 没有的话老老实实用 VimScript 去实现它,这不是折磨人么?
Sublime里面可以用原生 Python 写扩展,比 VimScript爽,但是 sublime 的插件能做的事情还不及VimScript的一半,所以怎么能指望他们能写出高端的功能来呢?
3. 强大:
Atom的内核 Electron (原来的 Atom-shell)可以理解成:Chromium + Node.JS,而整个Atom的界面,你可以理解成就是一颗 HTML 的 DOM 树结构,这意味着你可以这样:
var div = document.createElement("div");
div.innerText = "abc";
atom.workspace.addBottomPanel(div);
大量的前端开发技术和 Node.JS 基础模块供你任意使用,正是由于近年 Chromium / node.js 系列技术的成熟,和 Atom / Visual Studio Code 这类基于前端技术的客户端软件的成功,让我看到了客户端(桌面+移动)软件开发的新方向。
做VIM/Emacs不能做的事情
Vim/Emacs过去给人的映像是:几乎能做任何事情,确实如此,但毕竟是二三十年前的东西了,而他们一直坚挺到现在一方面是操作便利,更重要的是这么长时间还没有出现一款又开源又具备同样操作便利性和可扩展性的编辑器,所以Vimer, Emacser 们最乐意展示给别人看的就是他们又安装了什么插件,急于展示可以把 Vim / Emacs 装扮成了一个多像 IDE 的东西,而今天这个“可以做任何事情”的高度可定制特性已经被Atom所吸收并完全超越,就像 Atom 的开发blog:“ Introducing Atom” 上说的一样,对易用性和可展性 “决不妥协” :
We think we can do better. Our goal is a zero-compromise combination of hackability andusability: an editor that will be welcoming to an elementary school student on their first day learning to code, but also a tool they won't outgrow as they develop into seasoned hackers.
抛开易用性的这个 Atom 的明显优势不说,前面其实已说了不少 Atom 比 Vim/Emacs 更灵活强大的地方,可能有些人还有疑惑,不是说 Emacs “没有不能做的事情” 么?你看 Atom的面板里面可以嵌入一个 Terminal,Vim/Emacs一样可以嵌入啊,为何还说 Atom 比它强啊?
没错,Vim用久了会产生心理舒适区,多模式编辑使人神清气爽,命令化文本处理让你赏心悦目,但是受限于本身机制用久了会容易痛苦挣扎:虽然vim的各种扩展似乎什么事情都能做,但每个扩展却只能做到70分,总有那么30%的地方做不到位。所以用的时间长了,上半身爽的要死,下半身痛不欲生。。。。
Vim/Emacs即便大部分扩展功能也都可以称为“能用”,可几十年的历史包袱太沉,很多事情对他们来讲就是禁区,比如诡异的标签功能,容易误操作的buffer/窗口切换,缺乏异步机制,编译时间长只有傻等着,无法跟Atom一样边读代码,边运行程序看结果,对照输出结果和源代码找问题,连实现个内嵌终端都用了若干年,还实现的那么别扭。。。。。。。。。
这类硬伤有许多,再举个最简单的例子,minimap,就是 sublime那种大家喜欢的文档缩略图,这个现代编辑器必备的功能,谁能用 Vim/Emacs 实现一下看看?Atom 可以衍生出 Visual Studio Code 这样漂亮的编辑器,Vim/Emacs能衍生么?Atom可以随便用各种先进的前端技术,不当可以嵌 Terminal我甚至可以再 Atom 嵌入一个 js版本的 DOSBOX 玩老游戏《命令与征服》:
https://archive.org/details/softwarelibrary_msdos_games
当然这样并没有任何卯用,但是如果在 Atom里面内嵌一个浏览器,方便的实时预览html/css的效果呢?或者 Atom 里面内嵌一个 Markdown Previewer ,实时查看 Markdown 的效果呢?请问 Vim/Emacs 里怎么实现法?
Atom插件演示:markdown实时预览,左边写右边即时更新,100%兼容github的markdown语法
Atom插件演示:正则表达式图形化,鼠标移动上去自动显示
十分期待未来各种免费开源数学计算库同atom稍微集成下,就可以让你左边写一个等式,右边图表就能出来,是多麽爽的一种体验啊?Atom插件演示:color picker,快捷键打开取色面板,取完后直接生成代码插入光标之后
Atom插件演示:代码中表示颜色的语句直接用该颜色上色,可以根据文件扩展名,对特定文件打开
短短两年的时间,这么多优秀的插件,只想说,如今 Atom 作为 Vim/Emacs 的继承者和超越者出现了,所以社区对 Atom 的反应也是热烈的,看看下面一组数据,截止今天(2016年3月15日),Atom共有扩展插件 3500+ 个,发布不到两年的时间,这是什么概念呢?
- Sublime的插件(Stats - Package Control)大概 3500+个,但是sublime发布了5年的时间。
- Emacs 的插件大概有2900个,可Emacs发布到今天已经过去 25+年的时间。
- Vim 的各种插件虽然有9000个,但是Vi/Vim系列的历史长达 30+年,是atom的15倍。
这就叫社区的活跃度的区别,为什么短短两年那么多开发者先后给atom贡献了各种高质量的扩展,为什么大家对atom的热情那么高?为何好多人接触了atom一段时间后都深深的爱上了它?这是有原因的。
再谈性能优化
很多人错误的觉得 Atom慢是因为使用了 JavaScript/Coffee 等 Web 技术,所以先天慢,其实这是个误区,即便使用 Web 技术它也还能快很多,同时再慢可以往C++层的 Electron 挪啊,这也是这几个版本优化的一些方向,基于 Atom 开发的 Visual Studio Code 可以那么流畅, Atom 性能优化空间还很大,了不起多参考下自己的儿子,同样开源的 vscode怎么做的。
同时 Atom编辑器1.0版本以来性能得到了很大的提升,主要是两个方面,一方面是js层的各种渲染优化,控件优化,延迟绘制,延迟加载,只绘制当前需要的东西等,另外一方面是将一些核心数据结构移动到 Electron 的 C++层,如今1.54版本性能较去年版本已经有了本质区别,运行时加载是慢些(但也比eclipse快很多),实际使用并没觉得不如别的编辑器,况且,js层的优化和C层的优化未来还有很大的空间可以进步。
不过我不太喜欢 vscode 使用 Typed Script 进行开发,用点标准技术不行么,Atom使用 JavaScript/Coffee 写的多爽,如今 Atom 正在准备慢慢的切换到 JavaScript 的新标准 ES6 上。其次 vscode 快是快在“做的事情少”,主要是可扩展性方面的努力远不及 Atom,插件机制相对弱智,所以 vscode 的社区如今还不是特别活跃,扩展也少,发布一年多只有差不多300+个扩展,远不如 Atom 的情况,如果 vscode 还是按照现有结构开发下去,可能永远不会拥有 Atom的灵活度,这样再未来就无法拥有各种丰富多彩的插件。
再说开源免费
UltraEdit 单用户版本价格: 79 美刀
UltraEdit 服务器版价格: 229 美刀(多人登录同一台服务器的桌面使用),企业版更贵
EditPlus 单用户版价格: 35 美刀,而且还只有windows版本,
Sublime 单用户版价格:70 美刀
TextMate 单用户版价格:48 欧元,而且还只有mac版本。
这些都是钱啊,可能你会说可以免费试用或者破解啊,是的个人可以,但正常来说sublime这些试用指不能拿来搞生产不能拿来工作的,个人你用用可以,但国外人家守规矩,不会乱用,这意味着失去一大批为其开发扩展的国外开发者,同时站在公司考虑IT方案的角度,免费试用和破解将来都是潜在的麻烦,现在上百人的公司微软都会来收windows的钱了,版权问题越来越严肃,你得把这笔潜在费用考虑进去,同时这些闭源的或者单平台的东西,并不值得再上面花费过多精力和投资。
抛开扩展性问题和价格问题,我们再来看各个热门的免费编辑器的试用情况:
Notepad++:免费,开源,只能运行于windows
PSPad:免费,不开源,只能运行再 Windows
Gedit:免费,开源,只能跑再 GNome下,Ubuntu用用,Windows/mac版本简直是残缺的。
Programmer's Notepad : 免费开源,只能跑 Windows
Notepad2:免费bu不开源,只能跑 Windows
更关键的是:闭源的东西个人作者可能失去兴趣不再更新,商业公司的话,你需要一个功能,就只能无限期的等待他们发慈悲加入进去。而免费开源的很多其他编辑器除去平台兼容性问题外,更重要的时扩展性差。
而同时满足:免费+开放+强扩展性的编辑器如今就只出现过三个:Vim / Emacs / Atom。他们是真正属于使用者的编辑器,他们能变成使用者希望变成的样子。这些曾经出现过得收费的或者免费的编辑器,凭借着一两个自身独有的 “卖点”,再某些时间段内都曾经流行过,可就像流星一样一闪而过,如今他们都统统完成了自己的历史使命,新的一页可以翻开了。终端环境的话确实 Vim / Emacs 继续下去,但桌面环境的话,Atom将会继续向前,走出新的一步。
Atom使用答疑
怎么取消末尾空白行自动剔除?
-- 禁用自带 whitespace 插件即可。
怎么将TAB从空格改为真TAB?
-- 设置->Tab Mode 从 Soft 改为 Hard,同时将长度设置为4
我喜欢查看 空格和 TAB,还有换行符,让他们显示出来?
-- Settings->Editor->Show Invisibles
如何取消括号补全?
-- 设置->Packages->禁用 Bracket 插件即可。
我从 sublime 过来,如何增加文档缩略图 minimap?
-- 设置->Install->安装 MiniMap 即可
如何启用Vim模式?
-- 设置->Install->VimMode
如何禁止按回车实现自动补全(有时想换行但是变成使用补全了)?
-- 设置->Packages->Autocomplete Plus->将Tab+Enter改为Tab only
我是 C/C++ 开发者,如何一键编译一键执行代码?
-- 安利下我自己写的插件:Atom有什么优秀插件? - 韦易笑的回答
我是前端开发者,用惯了 Sublime的 Emmet,Atom下怎么办?
-- 也有 Emmet。
国内有时无法自动下载安装 package怎么办?
-- 等三五分钟重试,有些cdn的ip (amazon) 被gfw掉了,或者全局代理翻墙,或者直接从github上clone到 ~/.atom/packages下手动安装即可。
ATOM的编码如何自动识别GBK的文件呢?
-- Atom开发组调研了若干编译器和firefox等浏览器自动识别编码的代码后,发现这是一个完全不严谨基本靠猜的工作,为保证安全性,atom默认打开文件时是指定文件编码为utf-8(可改),你可以改为GBK,但这样对utf-8的文件不友好了。atom有自动识别功能,要在打开文件后,ctrl-shift-u来打开编码选择面板,然后选择 auto detect。如果你无法接受这种默认方式的话,有一个叫做 auto-encoding的插件安装后可以帮你再打开文件的时候自动识别编码。
有时候.h文件被自动识别成C文件而不是cpp文件,导致语法高亮无法识别class等关键字怎么办?
-- 只需要在你的 config.cson 中的 core项目下加入这样几行即可:
core:
customFileTypes:
"source.cpp": [
"h"
]
。。。。。。
VIM移植攻略
我在 Vim插入模式下习惯 inoremap C-HJKL来上下左右移动,十分方便,可到了Atom里该怎么办?
-- File -> Open Your Keymap,按照注释设置你的新的键位,如:'alt-j': 'core:move-down'。
我再 Vim下面喜欢设置各种indent,各种smart tab,tab expand再Atom里面怎么设置?
-- Settings 第一个面板就有。
我再 Vim 下面喜欢把大写的 HJKL 设置成 5h, 5j, 5k, 5l,这样按住shift实现快速移动,请问Atom怎么设置?
-- 你可能需要自己写点js代码了,不过这在vim里面也是不对的用法,你把J这个粘合两行的命令给覆盖了,行间移动我喜欢用vim的CTRL_U, CTRL_D来滚动半页,行内快速移动,我喜欢5w,或者直接fx。
我再 Vim中喜欢使用 Taglist/Tagbar 来进行索引,来到 Atom 有没有类似的插件?
-- 请使用:symbols-tree-view 代替之,而且不依赖ctags,实时分析当前文件内容,超级漂亮,使用ctrl-alt-o切换是否显示。其实内置功能 CMD-R (osx的键位,win下查一下,内置插件symbol-view)可以查看当前代码的函数列表,点击也可以跳转过去,同样也不依赖ctags,轻量级使用的话,内置这个足够了。
我从 Vim过来,如何实现Vim的 YouCompleteMe超级补全插件?
-- 安装 autocomplete-clang 或者 YouCompleteMe 插件即可。不过 Atom 本身内置的补全就已经很强大了,你可以先试试,况且Atom用这些东西还不像vim用 YCM那样还需要编译个带python的版本,还要编译clang一半天那么麻烦。
我在 Vim中喜欢用 vim-multiply-cursors 做批量操作,Atom怎么弄?
-- multi-cursor-plus
我再 Vim中写python,过来 Atom 下找不到顺手的工具了怎么办?
-- 你可以查看:autocomplete-python
。。。。。
如何快速打开文件,类似 e命令?
-- 十分强大的 advanced-open-file 插件
我想快速移动光标,怎么破?
-- 本身 Atom 就提供一系列快捷键用于快速移动,不够的话 http://atom.io/packages 下面有很多插件可以搜索,可以找找类似 move, jump 的很多包是否适合,比如 move-by-paragraph,了不起改两行js,不过 vim mode下面很多 { } 等命令快速移动光标已经能满足很多要求了。
我习惯用noremap定义很多自己习惯的组合操作,一个快捷键完成一堆命令,这该怎么移植?
-- keymap时使用组合命令需要自己写两行 ~/.atom/init.coffee,见官方文档:https://atom.io/docs/latest/behind-atom-keymaps-in-depth,这对喜欢折腾的 Vimer 应该不是难事,同时有人写了个扩展插件专门做这件事情的,可以看看能不能用:https://atom.io/packages/sequential-command。
。。。。。。
这段会不断更新补充,关于各种编辑器过来的人的习惯,喜欢折腾的Vim用户,Atom给大家足够折腾的空间,用不着刻意把 Atom 装扮成一个100%的vim,随着时间的推移用 Atom的方式使用Atom能让你获得更高的效率。
简单用一下的话,这样就可以了:
左边是 Atom再带的 Tree View,可以用来管理项目或者直接管理文件,右边是taglist/tagbar 的代替者:symbol-tree-view,中间文件分两边同时编辑两个文件,上面分tab,按cmd+数字直接跳转,左右两边panel设置快捷键组合切换,下面的Atom Shell Commands调用编译器编译工程或者单个源文件,编译器的错误输出可以根据正则匹配出对应出错的文件名和行号,快速跳转。
用了autocomplete-python插件来补全python,其他语言的话,系统自带的autocomplete-plus以经足够我用了,十分喜欢YCM的人,autocomplete-clang可以满足你们。
注:Atom是通用编辑器,真的写java我还是会用eclipse这种针对语言级别的IDE来调试安卓或者管理模拟器,但是其他语言,我现在都完全切换Atom了。
Vim/Emacs的世界里有个著名的笑话:“世界上只有三种程序员:使用Emacs的程序员,使用Vim的程序员和使用其他编辑器的程序员”,如今可以改一改了。
最后开个小玩笑,
使用其他编辑器的感觉是:哦,原来是这样啊。
使用Vim/Emacs的感觉是:哇,居然能这样啊,(又用一段时间再次)哇,居然能这样啊。
然而使用Atom的感觉是:Oh my god, Oh, my god !! oh ! oh! ... oh! (最后激动的话都说不完整了)。
-----
利用:
当时因Sublime Text 3 那酷炫的界面而关注IDE ,但是作为一个经常为用盗版而内疚的zhuangbilier ,经过多方搜索,发现还有个同样酷炫的ATOM 名字也好听,而且还免费。。。他妈太符合我的屌丝气质了。
这时候我要重复下知乎各大V经常熬的鸡汤:免费的就是最贵的!
下面是用了ATOM后硬件升级步骤(注:都是一步一步来的,不是一下子买齐的!心里憋屈呀!):
1.120G固态硬盘。
2.AMD A10 7700K +A78主板。
3.罗技G500鼠标+G105键盘。
4.购入AOC 2.5K LV253 专业显示器+ 旋转支架。(我原来的是DELL U2312HM,准备双显。)
5.显示器回来了,主板接口不支持,换换换。
6.AMD R250X显卡 。
你看看,为了省那点钱,都可以买Sublime 正版了。
但是你要问我 ATOM好不好,我的回答是 :吼啊!!!!
注:(Sublime Text 3 也一起用,但是主用ATOM ,上面换件都是因为ATOM.)
- 模块化思路很好。
- 开发初期没有开源,现在完全开源。
- 各种模块支持也使得以前一些答案批评的问题得到解决。
- 然而存在资源占用过多(可能还有内存泄漏),能耗大的问题,速度慢功耗大对于某些用户来说是不能忍受的问题。
你以为它是一个编辑器吗?它的目标是将 github 打造成 cloud server,而 editor 不过是终端入口,就像周鸿祎的360安全卫士,搜狗的输入法,当然,github 更体面更优雅,更容易得到程序员的追捧。
如果能成,将灰常牛逼。
vi: 编辑器之神
emacs: 神之编辑器
我希望有一款无缝的编辑器:本地的性能,云端的统一(包括提供 realtime 环境)。就像编辑界 evernote。你甚至能代码搜索、分享、社交,这更像是云时代的 emacs.
当然,这只是设想。
感受如下:
0 启动速度慢,但可以忍受
1 对git/markdown的原声支持,很方便
2 中文已经是个麻烦,还没有找到完美支持的方法,其他原生“不折腾”的方式
3 配置方便,早就看不惯sublime的全文字配置
4 插件/主题越来越丰富,包括vim mode/atom-beautify等,社区也很活跃
其他慢慢更新使用体验
==更新与2015-12-30
V1.3.2
优点:
中文正常,不再折腾
各种插件百花齐放
命令行管理插件很强大方便
缺点:
性能:16G的mbp上启动竟然要好几秒,不能忍;ubuntu下更是会把os拖死
插件:mac下总会提示却少xx包之类;昨天还能正常使用,今天就报错了
刚切换到同源的微软家VS Code
什么插件少,社区差都不是问题,人家性能好!
首先看看 Atom Blog 的描述:
Sublime and TextMate offer convenience but only limited extensibility. On the other end of the spectrum, Emacs and Vim offer extreme flexibility, but they aren't very approachable and can only be customized with special-purpose scripting languages.
Sublime 和 TextMate 的扩展性有限,而 Emacs 和 Vim 的起点又太高,而 Atom 正是为了弥补这一空缺才出现的。
论扩展性,Emacs 和 Vim 毫无疑问是最强大,但是你首先要去学 Vim script、Emacs Lisp 这两种平时并不会用到的语言。而 Atom 所采用的 Javascript 有着更广泛的群众基础,也容易吸引更多的人为它写扩展。
此外,Web 是现在的主流,Atom 基于 node webkit,它天生有着 Web 的基因,这是 Emacs 和 Vim 无法比拟的(比如你可以直接开个 tab 预览 markdown)。
第一感觉是启动慢。
默认外观和配色还是很好看的,至少符合我的审美叭。
试了一下那个特效插件,确实是挺炫的。。。
python 自动补全的插件能力还算比较强,可以识别变量类型。比如 a = ""; 之后 a.可以出现 str 相关函数,而 a=1的时候则不会出现。这个在 sublime 下貌似没发现有这样的插件(有的话请一定要告诉我!射射~)
1. 基于chromium和js导致资源消耗过大,没事占个2G+内存,未激活也能占4%-8%左右的CPU时间,耗电太厉害,实现同样功能,macvim比atom省电一大半(笔电用户关注能效,平时用safari抛弃chrome也是基于此考虑)
2. 不支持透明背景(今后也没有增加此功能的计划)