专注于前端开发, 追求更好的用户体验, 更好的开发体验 [长沙前端QQ群:234746733]

Sublime Text 新建文件的模版插件: SublimeTmpl

写了个sublime的模版插件, 项目主页: https://github.com/kairyou/SublimeTmpl
这样就可以新建文件时使用模版的内容了, 目前添加了html/js/css/php/python/ruby的模版. 不需新建空白文件, 再从其他文件复制内容过来了.
已增加对Sublime Text3的支持.

使用:

1. ST菜单, File-New File (SublimeTmpl), 选择列表里的相应菜单, 可直接使用模版新建文件.
2. 命令, cmd+shift+p, 输入: "tmpl:", 可以找到创建文件的菜单列表.
3.快捷键, 默认快捷键见下面. 可以自己修改, 方法见"设置"部分.

默认快捷键:

ctrl+alt+h html
ctrl+alt+j javascript
ctrl+alt+c css
ctrl+alt+p php
ctrl+alt+r ruby
ctrl+alt++shift+p python
关闭默认快捷键:

Package Settings > SublimeTmpl > Settings - User, 增加disabled_keymap_actions配置:
"disabled_keymap_actions": "html, css" // 关闭html/css语法的快捷键(多个逗号分隔) "disabled_keymap_actions: "all" //关闭所有语法快捷键

安装:

方法1. 通过 Package Control
Package Control / Install Package, 搜索"SublimeTmpl" 或 "tmpl", 安装.
* [2012/08/01]已经通过Package Control审核

方法2. Github
打开项目主页, git clone到ST的Packages文件夹(\Data\Packages), 或直接把ZIP格式的下载下来解压到Packages文件夹(文件夹名称必须为:SublimeTmpl).

设置:

菜单: Preferences / Packages Settings / SublimeTmpl, 可以编辑菜单/快捷键/新语法等等.

如果你想贡献自己的package, 可以参考我这篇文章的介绍:
https://xhl.me/archives/how-to-submit-a-sublime-package/

新增特性:

1. 用户自定义模板 (Thanks @Xu Cheng)
自定义模板路径: "Data\Packages\User\SublimeTmpl\templates" 目录, 会优先使用(可以参考:默认的模板).
默认模版路径: "Data\Packages\SublimeTmpl\templates" 目录.
用自己自定义的模板: 推荐把默认模版目录的*.tmpl文件 复制到 自定义模板路径, 再去修改.

2. 模板支持 ${date} 变量
settings - user里面可以修改${date}默认的输出格式("%Y-%m-%d %H:%M:%S"), 比如改成: "date_format" : "%Y-%m-%d"

3. 模板支持自定义 attr
settings - user里添加:

"attr": {
    "author": "your name" ,
    "email": "[email protected]",
    "link": "http://yours.com",
    "hello": "word"
}

就能在模板中使用 ${author} ${email} ${link} ${hello} 变量
Thanks @vfasky (Blog)

4. 保存文件时支持: ${saved_filename}, ${saved_filepath} 变量, settings - user里添加:
"enable_file_variables_on_save": true, // 开启
文件保存时, 上面的2个变量会替换为: 保存的文件名, 和文件路径.

5. 支持: ${project_base_name}, ${project_path} and ${platform} 变量, settings - user里添加:
"enable_project_variables": true, // 开启
Note: 仅ST3支持, 上面的3个变量会替换为: 项目名, 项目路径, 当前系统环境.

另外, 关于新增语言的附加说明

1. 新增SublimeTmpl里面没有的语言

1.1 新增.tmpl文件:
自定义模板目录 (`Preferences - Browse Packages`, `User/SublimeTmpl/templates`), 新增比如 `html5.tmpl`.

1.2 配置语言:
首先参考: `Packages Settings / SublimeTmpl / Settings - Default` 的默认设置.
新增语法, 选择: `SublimeTmpl / Settings - User`, 比如:

{
    "html5": { // new
        "syntax": "Packages/HTML/HTML.tmLanguage",
        "extension": "html" // default_extension
    },
    "vue": { // new
        "syntax": "Packages/Vue Syntax Highlight/vue.tmLanguage",
        "extension": "vue"
    },
    // "disable_keymap_actions": "html, js, python", // "all"
    "enable_project_variables": true, // ${project_base_name}, ${project_path} and ${platform}
    "enable_file_variables_on_save": true, // ${saved_filename}, ${saved_filepath} on save file
    "attr": {
        "author": "Your Name",
        "email": "[email protected]",
        "link": "http://example.org"
    }
}

`html5`:对应`html5.tmpl`, `syntax`是Packages目录内的syntax路径, `extension`是默认保存时使用的扩展名.

新增开始菜单: `SublimeTmpl / Settings - Menu`, 参照 `Menu - Default`.
新增快捷键: `SublimeTmpl / Key Bindings User`, 参照 `Key Bindings Default`.

2. 新增Sublime的语言

这个我也没新建过, 可以去Package Control或者github上面找个其他人添加的新语言, 参考参考.
如果没找到别人写好的, 可以参考如下网址, 自己做:
http://docs.sublimetext.info/en/latest/extensibility/syntaxdefs.html (官方文档, 利用AAAPackageDev这个插件制作)
http://manual.macromates.com/en/language_grammars (textmate的doc, 和sublime大部分是相同的)
https://github.com/LearnBoost/stylus/blob/master/editors/Stylus.tmbundle/Syntaxes/Stylus.tmLanguage (别人写好的语法, 可以和自己新建的对比)

/ 分类: 工具,实践 / TrackBackhttps://xhl.me/archives/sublime-template-engine-sublimetmpl/trackback标签: sublime, 插件

已有 84 条评论 »

  1. likuku likuku

    感谢!你这个很好用。

    我参考了 TextMate 的python模板,编辑了你插件的默认 python 模板,增加了几乎必备的 sys 和 os 模块,还有 初始化main函数 如下:

    ${1:#!/usr/bin/env python
    }${2:#coding: utf8

    }${3:import sys
    }${4:import os

    }${5:def main():
    }${6: pass

    }${7:if __name__ == '__main__':
    }${8: main()
    }$0

  2. kairyou kairyou

    谢谢, 已经加上了.
    TM的找到了: https://github.com/textmate/python.tmbundle, python不常用, 希望这样修改能更方写python的朋友.

  3. sky!0ooo sky!0ooo

    与vim上的QuickTemplate差不多。。。怎么都往Sublime Text 上转

    1. kairyou kairyou

      是的, 就是想到了VIM的这个插件, 没发现ST2下有类似的, 就自己写了个. 我现在还是两个都用(vim基本只在Linux里用了), ST写前端的东西觉得比用VIM爽一些.

  4. mufeng mufeng

    请问,怎么高亮sublime里没有的语言?比如velocity,以vm为后缀的模板.

    1. kairyou kairyou

      SublimeTmpl-Key Bindings – Default, 添加新的时指定type参数("args": {"type": "velocity"}), Settings – Default, 添加"velocity", "syntax"指定你的syntax文件. velocity的语法文件需要你自己去找了.

      1. gypeter gypeter

        你好,我还是不太明白怎样添加sublime 中没有的语言,英文好像是syntax ,添加新的syntax,能举个例子吗?谢谢

  5. kairyou kairyou

    @gypeter
    给SublimeTmpl添加语法比较容易, 但是给sublime添加语言比较麻烦, 我在文章后面补上了, 希望可以帮到你.

  6. Jreen Jreen

    由于一些原因,我需要给PY加两种不同的语言,我需要修改sublime-menu增加我修改的python
    我的templates文件夹有两个python,只不过命名不同,比如说python(GBK).tmpl和python(默认)
    那么请问这种情况下怎么修改比较好,就是说在菜单上要加上2个python
    {
    "caption": "python",
    "command": "sublime_tmpl",
    "args": {
    "type": "python"
    }

    1. kairyou kairyou

      SublimeTmpl.sublime-settings, 加上: "python(GBK)": { "syntax": ... }
      然后sublime-menu, 加上: {caption: "python(GBK)"..."type": "python(GBK)" 就OK了.

  7. hongwei hongwei

    这段对于我来说,太给力了!正是我想要的!

添加新评论 »