Sublime Text 2 代码片断
原文:Snippets
不管是在编码,还是写畅销书,你都可能会需要一遍又一遍的用到一些文本的小片断。使用片断来结束这种单调无聊的码字吧,片断是一种智能的模板,它能在合适的上下文中插入你需要的文本内容。
创建一个新的片断,选择 Tools | New Snippet... Sublime Text 将为你生成一个片断的基本的骨架。
片断可以保存在任何的包文件夹中,但为了简单起见,你可以保存在 Packages/User 文件夹下。
格式
通常的片断存在于某一个 Sublime Text 的包中。它们是一些以 sublime-snippet 为扩展名的简单的 XML 文件。举例来说,你可以在 Email 包下面创建一个 greeting.sublime-snippet 的片断。
典型的版本的结构如下(包含默认提示):
<snippet>
<content><![CDATA[Type your snippet here]]></content>
<!-- Optional: Tab trigger to activate the snippet -->
<tabTrigger>xyzzy</tabTrigger>
<!-- Optional: Scope the tab trigger will be active in -->
<scope>source.python</scope>
<!-- Optional: Description to show in the menu -->
<description>My Fancy Snippet</description>
</snippet>
snippet 中包含了所有 Sublime Text 需要的信息,插入什么、是否插入、何时插入。
content
实际插入的内容,代码片断可以从简单到非常复杂,接下来的例子我们会看到。
在创建自定义的代码片断的时候,需要注意以下:
a、如果想得到字符 $ ,必须进行转义:\$
b、如果片断中包含缩进,统一使用 tab。插入片断的时候,如果 translateTabsToSpaces 选项打开,会自动将 tab 转换成 space
文本内容必须包含在 <![CDTAT[...]]> 中,否则将失效。
tabTrigger
定义了一个触发插入片断的字符序列,当输入该序列后,按下 tab 键将插入片断。
tab 是隐含的绑定,不需要特意指定。
scope
定义了该片断的作用域,也就是只有在指定的扩展名的文件里面才会生效。更多信息请戳:Scopes。
description
将会显示在片断的上下文菜单中,如果留空,将默认显示该片断的文件名。
通过以上内容,已经可以开始写一个自己的代码片断了。
特性
环境变量
片断可以从环境变量中访问上下文件信息。Sublime Text 会自动给以下列出来的变量赋值。
当然你也可以进行扩展,加入自己的变量。自定义的变量需要定义在 .sublime-options 文件中。
| $PARAM1, $PARAM2… | 传给 insert_snippet 命令的参数 |
| $SELECTION | 片断触发后将被选中 |
| $TM_CURRENT_LINE | 片断触发后光标所在行的内容 |
| $TM_CURRENT_WORD | 片断触发后光标所在单词 |
| $TM_FILENAME | 文件名(包含扩展名) |
| $TM_FILEPATH | 文件路径 |
| $TM_FULLNAME | 电脑用户名 |
| $TM_LINE_INDEX | 片断触发时光标所在的列,从0算起 |
| $TM_LINE_NUMBER | 片断触发时光标所在的行,从1算起 |
| $TM_SELECTED_TEXT | 同 $SELECTION |
| $TM_SOFT_TABS | 如果 translate_tabs_to_spaces 为 true 时 YES,否则 NO |
| $TM_TAB_SIZE | 每个 tab 需要的 space 数量,由 tab_size 控制 |
看几个使用了变量的片断例子:
====================================
USER NAME: $TM_FULLNAME
FILE NAME: $TM_FILENAME
TAB SIZE: $TM_TAB_SIZE
SOFT TABS: $TM_SOFT_TABS
==================================== # Output:
====================================
USER NAME: guillermo
FILE NAME: test.txt
TAB SIZE: 4
SOFT TABS: YES
====================================
字段
在字段的标记下,你可以通过按 tab 键依次的在代码片断中跳转位置。字段的作用就是当你插入片断的时候帮助你完成个性化的设置。
First Name: $1
Second Name: $2
Address: $3
以上的例子中,当你按下 tab 后光标会跳到 $1 的位置。当第二次按 tab,将跳转到 $2,依此类推。当然,你也可以按 shift+tab 来返回上一个位置。如果在按完最高的那个 tab 之后再按 tab,Sublime Text 将把光标定位到片断内容的最后,这样你就可以进入普通的编辑模式了。
如果你想控制最后的定位点的位置,使用 $0 来标记。
可以在任何时间,通过按 Esc 退出字段的循环。
镜像字段
相同的字段将互相标记为镜像字段:当你编辑第一个的时候,剩下的地方将被填充同样的内容,也就是在相同的字段的位置都会出现光标,所以接下来的输入对所有字段位置都有效。
First Name: $1
Second Name: $2
Address: $3
User name: $1
在这个例子中,“User name” 后面的位置将被填充为和 “First Name” 后面位置一样的值。
占位符
稍微扩展一下字段的语法,你就可以为一个字段定义一个默认值。当你的有一个比较通用的代码片断,但同时你又想很方便的自定义的时候,占位符就非常有用。
First Name: ${1:Guillermo}
Second Name: ${2:López}
Address: ${3:Main Street 1234}
User name: $1
变量也可以用作占位符:
First Name: ${1:Guillermo}
Second Name: ${2:López}
Address: ${3:Main Street 1234}
User name: ${4:$TM_FULLNAME}
还可以嵌套占位符:
Test: ${1:Nested ${2:Placeholder}}
替换
除占位的语法外,还可以通过替换来执行更复杂的操作。使用替换来动态的生成文本。
替换的语法如下:
${var_name/regex/format_string/}
${var_name/regex/format_string/options}
var_name
变量名:1,2,3...
regex
Perl 风格的正则表达式。更多请戳:Boost library reference for regular expressions
format_string
戳上面那个链接
options
可选的。可以是以下的任意一种:i 不区分大小写、g 替换全局、m 匹配多行
通过替换功能,以下例子中,轻松的得到下划线:
Original: ${1:Hey, Joe!}
Transformation: ${1/./=/g}
# Output:
Original: Hey, Joe!
Transformation: =========
获取当前文件名(不包含扩展名):
<snippet>
<content><![CDATA[
using UnityEngine;
using System.Collections; public class ${TM_FILENAME/(.+)\..+/$1/} : MonoBehaviour { // Use this for initialization
void Start() {
${1}
} // Update is called once per frame
void Update() { } }]]></content>
<tabTrigger>ucs</tabTrigger>
<description>Unity Class</description>
<scope>source.cs</scope>
</snippet>
Sublime Text 2 代码片断的更多相关文章
- sublime text snippet代码片断
$0 代表补全代码后放的位置 0 的权重是最低的 $1 最高 也等于${1:} ${1: name} 1输入点的序号(1权重最高) name 自动补全的默认值 <conte ...
- sublime text 2代码片段(Snippet)功能的使用
“snippet”在英语里面是“片段”的意思.当我们编码时候,通常想要打几个简略的字符串,就出来一些固定的模板. 例如:使用snippet在新建文件时快速生成HTML头部信息等. 定义很简单,菜单:t ...
- 神器-Sublime Text 3 代码编辑器安装与使用
一.软件获取 1.软件下载地址:http://www.sublimetext.com/3. 2.注册机和汉化下载:http://files.cnblogs.com/files/1312mn/subli ...
- Sublime Text 格式化代码
1.添加快捷键 其实在sublime中已经自建了格式化按钮: Edit -> Line -> Reindent 只是sublime并没有给他赋予快捷键,所以只需加上快捷键即可 Prefer ...
- Sublime Text 3 代码格式化插件推荐 CodeFormatter
CodeFormatter CodeFormatter has support for the following languages: * PHP - By PHP_Beautifier* Java ...
- Sublime Text 格式化代码快捷键
首选项->按键绑定-用户 加入代码: {"keys": ["ctrl+alt+j"], "command": "reinde ...
- Sublime Text 新建代码片段(图解)
新建代码片段 1.打开NEW Snippet- 2.编辑代码片段 3.设置快捷键,按tab键执行 更多内容请见原文,原文转载自:https://blog.csdn.net/weixin_4451949 ...
- Sublime Text 配置代码
{ "font_face": "Courier New bold", "font_size": 15.0, "ignored_wo ...
- sublime text下代码太长brackethighlighter不能正确显示闭合高亮的解决方法
用brackethighlighter显示高亮一直都有这个问题...也没在网上找到解决方案,就一直凑合着用,今天翻着配置文件玩,改了参数发现问题解决了...... 修改search_threshold ...
随机推荐
- spring @condition 注解
spring @condition注解是用来在不同条件下注入不同实现的 demo如下: package com.foreveross.service.weixin.test.condition; im ...
- 判断一个 int 向量里是否有相同的数 并且距离在k之内 (2)
class Solution { public: bool containsNearbyDuplicate(vector<int>& nums, int k) { map<i ...
- MySQL Group Replication 技术点
mysql group replication,组复制,提供了多写(multi-master update)的特性,增强了原有的mysql的高可用架构.mysql group replication基 ...
- js 自带的 map() 方法
1. 方法概述 map() 方法返回一个由原数组中的每个元素调用一个指定方法后的返回值组成的新数组. 2. 例子 2.1 在字符串中使用map 在一个 String 上使用 map 方法获取字符串中 ...
- eclipse下项目死活不编译
工作中我们可能会遇到这种问题,项目在Eclipse下就是不编译,无论项目clean,重新build项目,重启eclipse,重启电脑都不好使.... 这时候我们可以把项目的jdk删掉,重新add一下, ...
- block的循环引用
什么是循环引用呢? 就是我引用你,你引用我,就会造成循环引用,双方都不会被销毁,导致内存泄漏. _block = ^{ NSLog(@"%@", self); }; block会 ...
- poj 2774
传送门:http://poj.org/problem?id=2774 裸的后缀数组,我只是为了贴个版而已 代码 #include <cstdio> #include <cmath&g ...
- SAP Query工具(一 Overview)
SAP提供了3种Query工具 1,SAP Query 2,InfoSet (Ad Hoc) Query 3,QuickViewer 一般说Query是指第一种,SAP Query 1,SAP Que ...
- AChecker + Selenium2对需要登录的页面进行自动化可访问性测试
前言:这段时间还算比较空闲,我准备把过去做过的有些形形色色,甚至有些奇怪的研究总结一下,也许刚好有人用的着也不一定,不枉为之抓耳挠腮的时光和浪费的电力. 名词解释: 网站可访问性测试:国内基本没有 ...
- VM出现该虚拟机正在使用中的提示,让获取所有权限解决办法
今天打开虚拟机正要学习,结果说是虚拟机似乎正在使用中,让我重新获取权限.解决办法:打开提示的配置文件的位置,将一个以.lck结尾的文件夹删除或者保存为另外的文件名称,再打开虚拟机就OK了.