如果你不需要臃肿的IDE,那C++编写的Sublime Text绝对是快速开发的神器。它是介于Editor和IDE之间的一款软件,极速,占极少资源。
官方文档:http://www.sublimetext.com/docs/3/
神级代码编辑器 Sublime Text 全程指南
http://www.cocoachina.com/programmer/20150715/12550.html
新编码神器Atom使用纪要 | 太耗资源,类似Chrome
http://jeffjade.com/2016/03/03/2016-03-02-how-to-use-atom/
插件管理器 Package Control https://packagecontrol.io/installation
Ctrl + `
import urllib.request,os,hashlib; h = 'df21e130d211cfc94d9b0905775a7c0f' + '1e3d39e33b79698005270310898eea76'; pf = 'Package Control.sublime-package'; ipp = sublime.installed_packages_path(); urllib.request.install_opener( urllib.request.build_opener( urllib.request.ProxyHandler()) ); by = urllib.request.urlopen( 'http://packagecontrol.io/' + pf.replace(' ', '%20')).read(); dh = hashlib.sha256(by).hexdigest(); print('Error validating download (got %s instead of %s), please try manual install' % (dh, h)) if dh != h else open(os.path.join( ipp, pf), 'wb' ).write(by)
For Sublime3:
import urllib.request,os,hashlib; h = '6f4c264a24d933ce70df5dedcf1dcaee' + 'ebe013ee18cced0ef93d5f746d80ef60'; pf = 'Package Control.sublime-package'; ipp = sublime.installed_packages_path(); urllib.request.install_opener( urllib.request.build_opener( urllib.request.ProxyHandler()) ); by = urllib.request.urlopen( 'http://packagecontrol.io/' + pf.replace(' ', '%20')).read(); dh = hashlib.sha256(by).hexdigest(); print('Error validating download (got %s instead of %s), please try manual install' % (dh, h)) if dh != h else open(os.path.join( ipp, pf), 'wb' ).write(by)
快捷键:Ctrl+Shift+P
安装Vue高亮插件
Ctrl+Shift+P -> PCIP -> Vue Syntax Highlight
安装完,重新打开Sublime就可以高亮Vue了。
导出配置:备份以下整个目录
Windows: %APPDATA%\Sublime Text 3
“C:\Users
Sublime技巧,划重点
多重编辑: 双击(或Ctrl + D) -> Alt+F3
Ctrl + D选择当前光标所在的词并高亮该词所有出现的位置,再次Ctrl + D选择该词出现的下一个位置,在多重选词的过程中,使用Ctrl + K进行跳过,使用Ctrl + U进行回退,使用Esc退出多重编辑。
列模式: Ctrl + Shift + L可以将当前选中区域打散,然后进行同时编辑
有打散自然就有合并,Ctrl + J可以把当前选中区域合并为一行
跳转到文件 Ctrl + P会列出当前打开的文件
F12快速跳转到当前光标所在符号的定义处(Jump to Definition)
Sublime Text支持代码段(Code Snippet),输入代码段名称后Tab即可生成代码段。http://www.hongkiat.com/blog/sublime-code-snippets/
- 自定义Snippet
- "vues" --> 快速创建export default {所有元素}
格式化(Formatting)
Sublime Text基本的手动格式化操作包括:Ctrl + [向左缩进,Ctrl + ]向右缩进,此外Ctrl + Shift + V可以以当前缩进粘贴代码(非常实用)。
- [HTML/CSS/JS Prettify] 插件,格式化Vue文件:
安装后 tools->HTML/CSS/JS Prettify->Plugin Options - Default
在"html" allowed_file_extensions": ["htm", "html", "xhtml", "shtml", "xml", "svg","vue"] 加上vue就好了 - 格式化快捷键:Ctrl+Shift+H
用SublimeREPL以进行多行编码实验(Experiments)。
使用BracketHighlighter插件以高亮显示配对括号以及当前光标所在区域
"bracket_styles": {
"default": {
"icon": "dot",
"color": "brackethighlighter.default",
"style": "hightlight"
}
}
中文输入法(包括日文输入法)都有一个问题:输入框不跟随:
解决方法是安装 IMESupport 插件,之后重启Sublime Text问题就解决了。
个人使用的设置项(Miscellaneous Settings)
// 设置Sans-serif(无衬线)等宽字体,以便阅读
"font_face": "YaHei Consolas Hybrid",
"font_size": 12,
// 使光标闪动更加柔和
"caret_style": "phase",
// 高亮当前行
"highlight_line": true,
// 高亮有修改的标签
"highlight_modified_tabs": true,
Google为每一门主流语言都设置了其代码规范(Code Style Guideline)。我自己通过下面的设置使以规范化自己的代码。
// 设置tab的大小为2
"tab_size": 2,
// 使用空格代替tab
"translate_tabs_to_spaces": true,
// 添加行宽标尺
"rulers": [80, 100],
// 显示空白字符
"draw_white_space": "all",
// 保存时自动去除行末空白
"trim_trailing_white_space_on_save": true,
// 保存时自动增加文件末尾换行
"ensure_newline_at_eof_on_save": true,
#Preferences -> Setting 我的设置:
{
"color_scheme": "Packages/User/SublimeLinter/Monokai JSON+ (SL).tmTheme",
"ensure_newline_at_eof_on_save": true,
"highlight_line": true,
"highlight_modified_tabs": true,
"ignored_packages":
[
],
"match_brackets": false,
"match_brackets_angle": false,
"match_brackets_braces": false,
"match_brackets_content": false,
"match_brackets_square": false,
"match_tags": false,
"rulers":
[
80,
100
],
"tab_size": 2,
"translate_tabs_to_spaces": true,
"trim_trailing_white_space_on_save": true
}
# My Prefer Packages:
Babel
BracketHighlighter
Emmet
HTM-CSS-JS Prettify
IMESupport
JSON L18n Resource Editor
MarkdownLight
MarkdownLivePreview
Monakai JSON+
Package Control
Pretty JSON
Pug
SublimeLinter
SublimeLinter-contrib-eslint
Vue Syntax Highlight
Vuejs Snippets
Global Snippet:
v
vue - Vue instance
vued - Vue directive
vuef - Vue filter
vuenexttick - Vue.nextTick()
Component + Options/Data
vuec - Vue component
vueccomputed - Vue computed props
vuecdata - Vue component data
vuecmethods - Vue component methods
vuecmixins - Vue component mixins
vuecprops - Vue component props
vuecwatch - Vue component watch
Vue Resource
vueht - this.$http()
vuehtget - this.$http.get()
vuehtpost - this.$http.post()
Vue Router
vuert - this.$route
vuertgo - this.$route.router.go()
Directives:
v-bind - :prop="data"
v-el - v-el:el-name
v-else -
v-for -