HBuilder HTML 自定义代码块
=begin
本文档是HTML代码块的编辑文件。注意不要把其他语言的设置放到html里来。
HBuilder可使用ruby脚本来编辑代码块和增强操作命令。
1、编辑代码块
如果要新增一个代码块,复制如下一段代码到空白行,然后设定参数。
'Style'是代码块的显示名字;
s.trigger = 'style' 是设定激活字符,比如输入style均会在代码提示时显示该代码块;
s.expansion = '' 是设定该代码块的输出字符,其中$0、$1是光标的停留和切换位置。
snippet 'Style' do |s|
s.trigger = 'style'
s.expansion = '<style type="text/css" media="screen">
$0
</style>'
end
以上以HTML代码块做示例,js和css代码块类似,使用时注意避免混淆
2、编辑按键命令
如果要新增一个按键操作命令,复制如下一段代码到空白行,然后设定参数。
'Br'是命令名字;
s.key_binding = 'CONTROL+ENTER' 是设定按什么快捷键可以触发这个命令;
s.expansion = '<br/>' 是设定输出字符。
snippet 'Br' do |s|
s.key_binding = 'CONTROL+ENTER'
s.expansion = '<br/>'
end
操作时注意冲突,注意备份,有问题就还原。
多看看已经写的ruby命令,会发现更多强大技巧。
修改完毕,需要重启才能生效。
玩的愉快,别玩坏!
脚本开源地址 https://github.com/dcloudio/HBuilderRubyBundle ,可以把你的配置共享到这里,也可以在这里获取其他网友的版本
=end require 'ruble' with_defaults :scope => 'text.html entity.other.attribute-name.html' do |bundle| snippet 'data-' do |s|
s.trigger = 'data-'
s.expansion='data-${1:type/role/transition/icon/iconpos/*} = "$2"'
s.locationType='HTML_ATTRIBUTE'
end end with_defaults :scope => 'text.html text' do |bundle| snippet t(:html_4_strict) do |s|
s.trigger = 'doctype'
s.expansion = '<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"
"http://www.w3.org/TR/html4/strict.dtd">
'
end snippet t(:xhtml_1_frameset) do |s|
s.trigger = 'doctype'
s.expansion = '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Frameset//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd">
'
end snippet t(:xhtml_1_strict) do |s|
s.trigger = 'doctype'
s.expansion = '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
'
end snippet t(:xhtml_1_transitional) do |s|
s.trigger = 'doctype'
s.expansion = '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
'
end snippet t(:xhtml_11) do |s|
s.trigger = 'doctype'
s.expansion = '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
"http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
'
end snippet t(:movie) do |s|
s.trigger = 'movie'
s.expansion = '<object width="${2:320}" height="${3:240}" classid="clsid:02BF25D5-8C17-4B23-BC80-D3488ABDDC6B" codebase="http://www.apple.com/qtactivex/qtplugin.cab">
<param name="src" value="${1:movie.mov}"/>
<param name="controller" value="${4:true}"/>
<param name="autoplay" value="${5:true}"/>
<embed src="${1:movie.mov}"
width="${2:320}" height="${3:240}"
controller="${4:true}" autoplay="${5:true}"
scale="tofit" cache="true"
pluginspage="http://www.apple.com/quicktime/download/"
></embed>
</object>'
end snippet t(:html_4_transitional) do |s|
s.trigger = 'doctype'
s.expansion = '<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
'
end snippet 'input with label' do |s|
s.trigger = 'input'
s.expansion = '<label for="$2">$1</label><input type="${3:text/submit/hidden/button}" name="$2" value="$5" id="$2"/>'
end snippet t(:option) do |s|
s.trigger = 'opt'
s.expansion = '<option value="${1:option}">${1:option}</option>'
end snippet 'input' do |s|
s.trigger = 'input'
s.expansion = '<input type="$1" name="$2" id="$2" value="$3" />'
s.needApplyReContentAssist = true
end snippet 'textarea' do |s|
s.trigger = 'textarea'
s.expansion = '<textarea name="$1" rows="$2" cols="$3">$0</textarea>'
end snippet 'canvas' do |s|
s.trigger = 'canvas'
s.expansion = '<canvas id="$1" width="$2" height="$3"></canvas>'
end snippet 'iframe' do |s|
s.trigger = 'iframe'
s.expansion = '<iframe src="$1" width="$2" height="$3"></canvas>'
s.needApplyReContentAssist = true
end snippet t(:nbsp) do |s|
s.key_binding = 'OPTION+Space'
s.expansion = ' '
end snippet 'Br' do |s|
s.key_binding = 'CONTROL+ENTER'
s.expansion = '<br/>'
end snippet 'link' do |s|
s.trigger = 'link'
s.expansion = '<link rel="stylesheet" type="text/css" href="$1"/>'
s.needApplyReContentAssist = true
end snippet 'meta' do |s|
s.trigger = 'meta'
s.needApplyReContentAssist = true
s.expansion = '<meta name="$1" content="$2"/>'
end snippet 'meta_UTF8' do |s|
s.trigger = 'metautf'
s.expansion = '<meta charset="UTF-8"/>'
end snippet 'meta_GB2312' do |s|
s.trigger = 'metagb'
s.expansion = '<meta charset="GB2312"/>'
end snippet 'meta_nocache' do |s|
s.trigger = 'metanocache'
s.expansion = '<meta http-equiv="Pragma" content="no-cache" />'
end snippet 'meta_keywords' do |s|
s.trigger = 'metakeywords'
s.expansion = '<meta name="Keywords" content="$1"/>'
end snippet 'meta_description' do |s|
s.trigger = 'metadescription'
s.expansion = '<meta name="Description" content="$1"/>'
end snippet 'meta_viewport' do |s|
s.trigger = 'metaviewport'
s.expansion = '<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />'
end snippet 'script_google_jquery' do |s|
s.trigger = 'scriptjqg'
s.expansion = '<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js"></script>'
end snippet 'script_baidu_jquery' do |s|
s.trigger = 'scriptjqb'
s.expansion = '<script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>'
end snippet '<!--[if IE]>' do |s|
s.trigger = 'ifie'
s.expansion = '<!--[if IE]>
$1
<![endif]-->'
end snippet '<!--[if lte IE 6]>' do |s|
s.trigger = 'ifie6'
s.expansion = '<!--[if lte IE 6]>
$1
<![endif]-->'
end snippet '<select>...</select>' do |s|
s.trigger = 'select'
s.expansion = '<select name="$1">
<option value="$2">$3</option>
</select>'
end snippet 'dl' do |s|
s.trigger = 'dl'
s.expansion = '<dl>
<dt>$1</dt>
<dd>$2</dd>
</dl>'
end snippet 'ul' do |s|
s.trigger = 'ul'
s.expansion = '<ul>
<li>$1</li>
</ul>'
end snippet 'form' do |s|
s.trigger = 'form'
s.expansion = "<form action=\"$1\" method=\"${2:get}\">
$0
<input type=\"submit\" value=\"$3\"/>
</form>"
s.needApplyReContentAssist = true
end snippet 'input_text' do |s|
s.trigger = 'intext'
s.expansion = '<input type="text" id="$1" value="$2" />'
s.needApplyReContentAssist = true
end snippet 'input_button' do |s|
s.trigger = 'inbutton'
s.expansion = '<input type="button" id="$1" value="$2" />'
s.needApplyReContentAssist = true
end snippet 'input_image' do |s|
s.trigger = 'inimage'
s.expansion = '<input type="image" src="$1" />'
s.needApplyReContentAssist = true
end snippet 'input_password' do |s|
s.trigger = 'inpassword'
s.expansion = '<input type="password" name="$1" />'
end snippet 'input_search' do |s|
s.trigger = 'insearch'
s.expansion = '<input type="search" name="$1" required="$2" placeholder="Search" x-webkit-speech="$3" x-webkit-grammar="builtin:search" lang="zh-CN">'
end snippet 'input_submit' do |s|
s.trigger = 'insubmit'
s.expansion = '<input type="submit" id="$1" name="$2" />'
end snippet 'input_reset' do |s|
s.trigger = 'inreset'
s.expansion = '<input type="reset"/>'
end snippet 'img' do |s|
s.trigger = 'img'
s.expansion = '<img src="$1"/>'
s.needApplyReContentAssist = true
end snippet 'a_link' do |s|
s.trigger = 'al'
s.expansion = '<a href="$1"></a>'
s.needApplyReContentAssist = true
end snippet 'a_mailto' do |s|
s.trigger = 'am'
s.expansion = '<a href="mailto:$1"></a>'
end snippet 'video' do |s|
s.trigger = 'video'
s.expansion = '<video width="${1:800}" height="$2">
<source src="${3:myvideo.mp4}" type="video/mp4"></source>
<source src="${4:myvideo.ogv}" type="video/ogg"></source>
<source src="${5:myvideo.webm}" type="video/webm"></source>
<object width="$6" height="$7" type="application/x-shockwave-flash" data="${8:myvideo.swf}">
<param name="movie" value="$8" />
<param name="flashvars" value="autostart=true&file=$8" />
</object>
当前浏览器不支持 video直接播放,点击这里下载视频: <a href="${9:myvideo.webm}">下载视频</a>
</video>'
end snippet t(:script_w_external_source) do |s|
s.trigger = 'scsrc'
s.expansion = '<script src="$1" type="text/javascript" charset="${3:utf-8}"></script>'
s.needApplyReContentAssist = true
end snippet 'Script' do |s|
s.trigger = 'script'
s.expansion = '<script type="text/javascript" charset="utf-8">
$0
</script>'
end snippet 'style' do |s|
s.trigger = 'style'
s.expansion = '<style type="text/css">
$0
</style>'
end snippet '<!DOCTYPE html>' do |s|
s.trigger = 'doctype'
s.expansion = '<!DOCTYPE HTML>'
end snippet 'html' do |s|
s.trigger = 'html'
s.expansion = '<html>
<head>
<title>$0</title>
</head>
<body> </body>
</html>'
end snippet 'h1' do |s|
s.trigger = 'h1'
s.expansion = '<h1>$0</h1>'
end snippet 'h2' do |s|
s.trigger = 'h2'
s.expansion = '<h2>$0</h2>'
end snippet 'h3' do |s|
s.trigger = 'h3'
s.expansion = '<h3>$0</h3>'
end snippet 'h4' do |s|
s.trigger = 'h4'
s.expansion = '<h4>$0</h4>'
end snippet 'h5' do |s|
s.trigger = 'h5'
s.expansion = '<h5>$0</h5>'
end snippet 'h6' do |s|
s.trigger = 'h6'
s.expansion = '<h6>$0</h6>'
end snippet 'table' do |s|
s.trigger = 'table'
s.expansion = '<table border="$1" cellspacing="$2" cellpadding="$3">
<tr><th>${4:Header}</th></tr>
<tr><td>${5:Data}</td></tr>
</table>'
end snippet 'head' do |cmd|
cmd.trigger = 'head'
cmd.expansion = "<head>
<meta charset=\"utf-8\"/>
<title>$1</title> </head>"
end snippet 'body' do |cmd|
cmd.trigger = 'body'
cmd.expansion = "<body>
$0
</body>"
end snippet 'div' do |cmd|
cmd.trigger = 'div'
cmd.needApplyReContentAssist = true
cmd.expansion = "<div class=\"$1\">
$0
</div>"
end snippet 'span' do |cmd|
cmd.trigger = 'span'
cmd.needApplyReContentAssist = true
cmd.expansion = "<span id=\"$1\">
$0
</span>"
end snippet 'fieldset' do |cmd|
cmd.trigger = 'fieldset'
cmd.expansion = "<fieldset id=\"$2\">
<legend>$1</legend> $0
</fieldset>"
end end # End Snippets with scope 'text.html text' # -----------------------------------------------------------------------------------
# Snippets that used env vars and needed to be converted to commands
with_defaults :scope => 'text.html - source', :input => :none, :output => :insert_as_snippet do |bundle| command t(:quick_br) do |cmd|
cmd.key_binding = 'M2+ENTER'
cmd.output = :insert_as_snippet
cmd.input = :none
cmd.invoke { "<br />" }
end command t(:quick_html_space) do |cmd|
cmd.key_binding = 'M2+SPACE'
cmd.output = :insert_as_snippet
cmd.input = :none
cmd.invoke { " " }
end command t(:emphasize) do |cmd|
cmd.key_binding = 'M1+M2+I'
cmd.input = :selection
cmd.invoke do |context|
selection = ENV['TM_SELECTED_TEXT'] || ''
if selection.length > 0
"<em>${1:#{selection}}</em>"
else
"<em>$0</em>"
end
end
end command t(:strong) do |cmd|
cmd.key_binding = 'M1+M2+B'
cmd.input = :selection
cmd.invoke do |context|
selection = ENV['TM_SELECTED_TEXT'] || ''
if selection.length > 0
"<strong>${1:#{selection}}</strong>"
else
"<strong>$0</strong>"
end
end
end command t(:wrap_selection_in_tag_pair) do |cmd|
cmd.key_binding = "CONTROL+9"
cmd.input = :selection
cmd.invoke do |context|
selection = ENV['TM_SELECTED_TEXT'] || ''
if selection.length > 0
"<${1:p}>#{selection.gsub('/', '\/')}</${1:p}>"
else
"<${1:p}>$0</${1:p}>"
end
end
end
end #end of 'text.html - source' with_defaults :scope => 'text.html text', :input => :none, :output => :insert_as_snippet do |bundle|
command t(:ie_6_and_below) do |cmd|
cmd.trigger = '!'
cmd.invoke do |context|
value = (ENV['TM_SELECTED_TEXT'] || '').length > 0 ? ENV['TM_SELECTED_TEXT'] : ' IE Conditional Comment: Internet Explorer 6 and below '
"<!--[if lte IE 6]>${1:#{value}}<![endif]-->$0"
end
end command t(:ie_6) do |cmd|
cmd.trigger = '!'
cmd.invoke do |context|
value = (ENV['TM_SELECTED_TEXT'] || '').length > 0 ? ENV['TM_SELECTED_TEXT'] : ' IE Conditional Comment: Internet Explorer 6 only '
"<!--[if IE 6]>${1:#{value}}<![endif]-->$0"
end
end command t(:ie_7_and_above) do |cmd|
cmd.trigger = '!'
cmd.invoke do |context|
value = (ENV['TM_SELECTED_TEXT'] || '').length > 0 ? ENV['TM_SELECTED_TEXT'] : ' IE Conditional Comment: Internet Explorer 7 and above '
"<!--[if gte IE 7]>${1:#{value}}<![endif]-->$0"
end
end command t(:ie_8_and_above) do |cmd|
cmd.trigger = '!'
cmd.invoke do |context|
value = (ENV['TM_SELECTED_TEXT'] || '').length > 0 ? ENV['TM_SELECTED_TEXT'] : ' IE Conditional Comment: Internet Explorer 8 and above '
"<!--[if gte IE 8]>${1:#{value}}<![endif]-->$0"
end
end command t(:ie_9_and_above) do |cmd|
cmd.trigger = '!'
cmd.invoke do |context|
value = (ENV['TM_SELECTED_TEXT'] || '').length > 0 ? ENV['TM_SELECTED_TEXT'] : ' IE Conditional Comment: Internet Explorer 9 and above '
"<!--[if gte IE 9]>${1:#{value}}<![endif]-->$0"
end
end command t(:ie) do |cmd|
cmd.trigger = '!'
cmd.invoke do |context|
value = (ENV['TM_SELECTED_TEXT'] || '').length > 0 ? ENV['TM_SELECTED_TEXT'] : ' IE Conditional Comment: Internet Explorer '
"<!--[if IE]>${1:#{value}}<![endif]-->$0"
end
end command t(:not_ie) do |cmd|
cmd.trigger = '!'
cmd.invoke do |context|
value = (ENV['TM_SELECTED_TEXT'] || '').length > 0 ? ENV['TM_SELECTED_TEXT'] : ' IE Conditional Comment: NOT Internet Explorer '
"<!--[if !IE]><!-->${1:#{value}}<!-- <![endif]-->$0"
end
end command t(:wrap_in_jsp_tag) do |cmd|
cmd.scope = 'text.html string'
cmd.invoke {|context| "<?= #{ENV['TM_SELECTED_TEXT']} ?>" }
end
end
HBuilder HTML 自定义代码块的更多相关文章
- Hbuilder jQuery 自定义代码块
=begin 本文档是jquery代码块的编辑文件.修改其他的代码块,请在对应的激活代码助手点右下角的修改图标. HBuilder可使用ruby脚本来编辑代码块和增强操作命令. 1.编辑代码块 如果要 ...
- HBuilder js 自定义代码块
=begin 本文档是HBuilder预置的js代码块的文件.注意不要把其他语言的设置放到js里来. 如果用户修改此文档,HBuilder升级后会覆盖用户的修改,建议进入菜单 工具→扩展代码块 扩展相 ...
- HBuilder CSS 自定义代码块
=begin 本文档是CSS代码块的编辑文件.注意不要把其他语言的设置放到css里来. HBuilder可使用ruby脚本来编辑代码块和增强操作命令. 1.编辑代码块 如果要新增一个代码块,复制如下一 ...
- Xcode自定义代码块
到现在才发现原来Xcode有自定义代码块这么神奇的功能,能简化很多无聊的敲重复代码的工作,真是感叹我怎么才知道!!! 具体的设置流程见:http://nshipster.cn/xcode-snippe ...
- webstrom自定义代码块的设置方法
webstrom里面的自定义代码块叫做活动模版 在文件 -> 设置 -> 编辑器 -> 活动模版可以打开 里面的$var$ 代表一个变量 两个相同的$var$在不全后可以同时修改, ...
- IDE MAC下的快捷键,自定义代码块。
快捷键 参考博客:http://blog.csdn.net/iguiyi/article/details/51853728 alt+f7查找在哪里使用 相当于eclipse的ctrl+shift+G ...
- vscode自定义代码块
vscode中设置自定义代码块打开首选项,选择用户代码片段,打开后选择编程语言选中后打开文件,按照格式编辑内容 "Print to console log": { "pr ...
- vs2015常用代码块与自定义代码块
常用代码块 代码段名 描 述 #if 该代码段用#if和#endif命令围绕代码 #region 该代码段用#region和#endregion命令围绕代码 ~ 该代码段插入一个析构函数 att ...
- IDEA 自定义代码块
使用快捷键(ctrl+alt+s)找到:从idea的菜单File->Settings->Editor->Live Templates 先添加Template Group,然后添加Li ...
随机推荐
- matlab 图片批量读取
1. 指定的路径 单目录data所有图片 file_path = '.\data\';% 图片目录路径 img_path_list = dir(strcat(file_path,'*.jpg'));% ...
- SQL Server系统数据库备份最佳实践
原文:SQL Server系统数据库备份最佳实践 首先了解主要的系统数据库: 系统数据库 master 包含登录信息和其他数据库的核心信息 msdb 存储作业.操作员.警报.备份还原历史.数据库邮件信 ...
- opencv-阈值处理
从原理:http://www.opencv.org.cn/opencvdoc/2.3.2/html/doc/tutorials/imgproc/threshold/threshold.html 目标: ...
- .net卸载程序制作
原文:.net卸载程序制作 方法一: 在打包项目中添加文件msiexec.exe(一般在c:\windows\system32(系统目录中)找到). 在文件系统视图中选择应用程序文件,在msiexec ...
- C#动态调用WCF接口
C#动态调用WCF接口 写在前面 接触WCF还是它在最初诞生之处,一个分布式应用的巨作. 从开始接触到现在断断续续,真正使用的项目少之又少,更谈不上深入WCF内部实现机制和原理去研究,最近自己做一个项 ...
- 具体分析Struts工作流程
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvcXV3ZW56aGU=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA ...
- 网络编程I/O功能介绍
read和write #include <unistd.h> ssize_t read(int fd, void *buf, size_t count); ssize_t write(in ...
- SICP 习题 (1.37)解题总结
SICP 习题 1.37是一条非常长的题目,主要讲的是无穷连分式.无穷连分式对我来说又是一个陌生的概念,于是又去百度了一番,发现无穷连分式也是一个非常有意思的话题,涉及到无理数的表达.只是我建议大家还 ...
- Oracle 使用
Oracle 日志文件 摘要: 本篇博文呢主要是介绍 Oracle 日志文件的管理, 对 Oracle 日志文件呢,有两个比较关键的名词, 即日志文件组 LogFileGroup 和日志文件 LogF ...
- win7或windows server 2008 R2 被远程登录日志记录 系统日志
事件查看器 → Windows 日志 → 安全 (win7 事件查看器 打开方式 :计算机 右键 → 管理 → 计算机管理 → 系统工具 → 事件查看器 windows server 2008 ...