=begin
本文档是HBuilder预置的js代码块的文件。注意不要把其他语言的设置放到js里来。
如果用户修改此文档,HBuilder升级后会覆盖用户的修改,建议进入菜单 工具→扩展代码块 扩展相应的代码块。
若修改本文档,需要重启才能生效。修改过程中注意备份。
脚本开源地址 https://github.com/dcloudio/HBuilderRubyBundle
、编辑代码块
如果要新增一个代码块,复制如下一段代码到空白行,然后设定参数。
snippet "document.getElementById" do |s| #'document.getElementById'是代码块的显示名字;
s.trigger = "dgi" #'dgi' 是激活字符,比如输入dgi均会在代码提示时显示该代码块;
s.expansion = "document.getElementById(\"$1\")" #expansion是设定该代码块的输出字符,其中$、$1是光标的停留和切换位置。
#如果输出涉及到换行和tab,也需严格在这里使用换行和tab。
#输出双引号在前面加\来转义,输出$使用$$转义
s.needApplyReContentAssist = true #输入代码块后立即在$1位置激活代码提示助手
end
、编辑按键命令
如果要新增一个按键操作命令,复制如下一段代码到空白行,然后设定参数。
command t(:multicomment) do |cmd| #:首先起个名字,multicomment是名字
cmd.key_binding = 'M1+M2+/' #这里绑定触发按键,这里是Ctrl+Shift+/
cmd.input = :selection #输入内容是选中区域的内容
cmd.invoke do |context|
selection = ENV['TM_SELECTED_TEXT'] || ''
# 如果选区长度大于0,则输出如下字符。回车符就使用真实回车。如下输出即在选中内容前后加上/* */的注释
if selection.length >
"/*
${:#{selection}}
*/"
end
end
end
=end require 'ruble' with_defaults :scope => "source.js" do #=====JS代码块编辑=============================== snippet t(:object_method) do |s|
s.trigger = ":f"
s.expansion = "${1:method_name}: function(${2:attribute}){
$
}${:,}"
end snippet "function" do |s|
s.trigger = "funn"
s.expansion = "function ${1:function_name} ($2) {
$
}"
end snippet t(:function_anonymous) do |s|
s.trigger = "funan"
s.expansion = "function ($1) {
$
}"
end snippet t(:function_closures) do |s|
s.trigger = "funcl"
s.expansion = "(function ($1) {
$
})($)"
end snippet t(:prototype) do |s|
s.trigger = "proto"
s.expansion = "${1:class_name}.prototype.${2:method_name} = function(${3:first_argument}) {
${:// body...}
};
"
end snippet t(:if) do |s|
s.trigger = "iff"
s.expansion = "if ($1) {
$
}"
end snippet t(:if_else) do |s|
s.trigger = "ife"
s.expansion = "if ($1) { } else{ }"
end snippet t(:if_compare) do |s|
s.trigger = "ifc"
s.expansion = "if ($1 == ${2:true}) { } else{ }"
end snippet t(:for) do |s|
s.trigger = "forr"
s.expansion = "for ($1) {
$
}"
end snippet t(:fori) do |s|
s.trigger = "fori"
s.expansion = "for (var i = 0; i < ${1:Things}.length; i++) {
${:Things}[i]
}"
end snippet t(:with) do |s|
s.trigger = "withh"
s.expansion = "with ($1){
$
}"
end
snippet t(:typeof) do |s|
s.trigger = "typeoff"
s.expansion = 'typeof($1)=="${2:undefined/boolean/function/number/object/string}"'
end snippet t(:switch_case) do |s|
s.trigger = "switchcase"
s.expansion = "switch (${1}){
case ${:value}:
break;
default:
break;
}"
end snippet "while" do |s|
s.trigger = "whilee"
s.expansion = "while (${1:condition}){ }"
end snippet "var i=0;" do |s|
s.trigger = "vari"
s.expansion = "var ${1:i}=${2:0};"
end snippet "var s=\"\";" do |s|
s.trigger = "vars"
s.expansion = "var ${1:s}=\"$2\";"
end snippet "var a=[];" do |s|
s.trigger = "vara"
s.expansion = "var ${1:a}=[$2];"
end snippet "var l=a.length;" do |s|
s.trigger = "varl"
s.expansion = "var ${1:l}=${2:a}.length;"
end snippet "var c = canvas" do |s|
s.trigger = "varc"
s.expansion = "var ${2:c} = document.getElementById(\"$1\").getContext(\"2d\");"
s.needApplyReContentAssist = true
end snippet "var xhr" do |s|
s.trigger = "varxhr"
s.expansion = "var ${1:xhr} = new XMLHttpRequest();
xhr.open(\"${2:GET/POST/PUT}\",\"$3\",${4:true/false});"
end snippet "return true;" do |s|
s.trigger = "returntrue"
s.expansion = "return true;"
end snippet "return false;" do |s|
s.trigger = "returnfalse"
s.expansion = "return false;"
end snippet "console.log();" do |s|
s.trigger = "log"
s.expansion = "console.log(\"$1\");"
end snippet "try{}catch(e)" do |s|
s.trigger = "trycatch"
s.expansion = "try{
$
}catch(e){
//TODO handle the exception
}"
end snippet "$ (document.getElementById)" do |s|
s.trigger = "dg"
s.expansion = "document.getElementById(\"$1\")"
s.needApplyReContentAssist = true
end snippet '$("")' do |s|
s.trigger = "dl"
s.expansion = "$$($1)"
s.needApplyReContentAssist = true
end
snippet '$("#")' do |s|
s.trigger = "dlid"
s.expansion = "$$(\"\#$1\")"
s.needApplyReContentAssist = true
end
snippet '$(".")' do |s|
s.trigger = "dlclass"
s.expansion = "$$(\".$1\")"
s.needApplyReContentAssist = true
end snippet "document.getElementById" do |s|
s.trigger = "dgi"
s.expansion = "document.getElementById(\"$1\")"
s.needApplyReContentAssist = true
end snippet "document.querySelectorAll" do |s|
s.trigger = "dqs"
s.expansion = "document.querySelectorAll(\"$1\")"
s.needApplyReContentAssist = true
end snippet "document.write" do |s|
s.trigger = "dw"
s.expansion = "document.write(\"$1\")"
end snippet "navigator.userAgent;" do |s|
s.trigger = "nuser"
s.expansion = "navigator.userAgent"
end snippet t(:object_value) do |s|
s.trigger = ":,"
s.expansion = "${1:value_name}:${0:value},"
end snippet t(:object_key) do |s|
s.trigger = ":"
s.expansion = '${1:key}: ${2:"${3:value}"}${4:, }'
end snippet t(:setTimeout) do |s|
s.trigger = "timeout"
s.expansion = "setTimeout(function() {$0}, ${1:10});"
end snippet t(:object_method_string) do |s|
s.trigger = ':f'
s.expansion = "'${1:${2:#thing}:${3:click}}': function(element){
$
}${:,}"
end snippet "@alias" do |s|
s.trigger = "@alias"
s.locationType="JS_DOC"
s.expansion = "@alias ${1:alias_name}"
end snippet "@author" do |s|
s.trigger = "@author"
s.locationType="JS_DOC"
s.expansion = "@author ${1:author}"
end snippet "@classDescription" do |s|
s.trigger = "@classDescription"
s.locationType="JS_DOC"
s.expansion = "@classDescription {${1:namespace}} ${2:description}"
end snippet "@constructor" do |s|
s.trigger = "@constructor"
s.locationType="JS_DOC"
s.expansion = "@constructor ${1:description}"
end snippet "@example" do |s|
s.trigger = "@example"
s.locationType="JS_DOC"
s.expansion = "@example ${1:example_code}"
end snippet "@exception" do |s|
s.trigger = "@exception"
s.locationType="JS_DOC"
s.expansion = "@exception {${1:exception_type}} ${2:description}"
end snippet "@extends" do |s|
s.trigger = "@extends"
s.locationType="JS_DOC"
s.expansion = "@extends {${1:parent_type}} ${2:description}"
end snippet "@function" do |s|
s.trigger = "@function"
s.locationType="JS_DOC"
s.expansion = "@function ${1}"
end snippet "@internal" do |s|
s.trigger = "@internal"
s.locationType="JS_DOC"
s.expansion = "@internal ${1}"
end snippet "@param" do |s|
s.trigger = "@param"
s.locationType="JS_DOC"
s.expansion = "@param {${1:boolean/function/number/object/string/AttrString/ClassString/ColorString/CSSString/CSSURIString/EventString/FontString/HTMLString/IDString/ImageURIString/JSURIString/MultimediaString/SelectorString/TagString/URIString}} ${2:param_name}"
end snippet "@private" do |s|
s.trigger = "@private"
s.locationType="JS_DOC"
s.expansion = "@private ${1}"
end snippet "@property" do |s|
s.trigger = "@property"
s.locationType="JS_DOC"
s.expansion = "@property ${1}"
end snippet "@return" do |s|
s.trigger = "@return"
s.locationType="JS_DOC"
s.expansion = "@return {${1:return_type}} ${2}"
end snippet "@see" do |s|
s.trigger = "@see"
s.locationType="JS_DOC"
s.expansion = "@see ${2:link}"
end snippet "@type" do |s|
s.trigger = "@type"
s.locationType="JS_DOC"
s.expansion = "@type {${1:boolean/function/number/object/string/AttrString/ClassString/ColorString/CSSString/CSSURIString/EventString/FontString/HTMLString/IDString/ImageURIString/JSURIString/MultimediaString/SelectorString/TagString/URIString}} ${2:param_name}"
end snippet "@userAgent" do |s|
s.trigger = "@userAgent"
s.locationType="JS_DOC"
s.expansion = "@userAgent ${1:browser1}:${2:version1},${3:browser2}:${4:version2}"
end end with_defaults :scope => "source.js", :input => :none, :output => :insert_as_snippet do |bundle|
=begin
command t(:multicomment) do |cmd| #:首先起个名字,multicomment是名字
cmd.key_binding = 'M1+M2+/' #这里绑定触发按键,这里是Ctrl+Shift+/
cmd.input = :selection #输入内容是选中区域的内容
cmd.invoke do |context|
selection = ENV['TM_SELECTED_TEXT'] || ''
# 如果选区长度大于0,则输出如下字符。回车符就使用真实回车。如下输出即在选中内容前后加上/* */的注释
if selection.length >
"/*
${:#{selection}}
*/"
end
end
end
=end
end

HBuilder js 自定义代码块的更多相关文章

  1. Hbuilder jQuery 自定义代码块

    =begin 本文档是jquery代码块的编辑文件.修改其他的代码块,请在对应的激活代码助手点右下角的修改图标. HBuilder可使用ruby脚本来编辑代码块和增强操作命令. 1.编辑代码块 如果要 ...

  2. HBuilder HTML 自定义代码块

    =begin 本文档是HTML代码块的编辑文件.注意不要把其他语言的设置放到html里来. HBuilder可使用ruby脚本来编辑代码块和增强操作命令. 1.编辑代码块 如果要新增一个代码块,复制如 ...

  3. HBuilder CSS 自定义代码块

    =begin 本文档是CSS代码块的编辑文件.注意不要把其他语言的设置放到css里来. HBuilder可使用ruby脚本来编辑代码块和增强操作命令. 1.编辑代码块 如果要新增一个代码块,复制如下一 ...

  4. vsCode与Hubilder中自定义代码块

    平常测试vue的一些属性时总要新增代码,引入文件,麻烦,顾自定义代码块来实现快速新增测试 一.打开设置 1.1 vsCode设置 点击后选择代码块所属的文件类型,比如在html中则选择html类型配置 ...

  5. Xcode自定义代码块

    到现在才发现原来Xcode有自定义代码块这么神奇的功能,能简化很多无聊的敲重复代码的工作,真是感叹我怎么才知道!!! 具体的设置流程见:http://nshipster.cn/xcode-snippe ...

  6. webstrom自定义代码块的设置方法

    webstrom里面的自定义代码块叫做活动模版 在文件 -> 设置 -> 编辑器 -> 活动模版可以打开 里面的$var$ 代表一个变量  两个相同的$var$在不全后可以同时修改, ...

  7. IDE MAC下的快捷键,自定义代码块。

    快捷键 参考博客:http://blog.csdn.net/iguiyi/article/details/51853728 alt+f7查找在哪里使用 相当于eclipse的ctrl+shift+G ...

  8. vscode自定义代码块

    vscode中设置自定义代码块打开首选项,选择用户代码片段,打开后选择编程语言选中后打开文件,按照格式编辑内容 "Print to console log": { "pr ...

  9. vs2015常用代码块与自定义代码块

    常用代码块 代码段名 描    述 #if 该代码段用#if和#endif命令围绕代码 #region 该代码段用#region和#endregion命令围绕代码 ~ 该代码段插入一个析构函数 att ...

随机推荐

  1. 使用Heroku,需要locale至zh_CN,代替zh-CN

    使用Heroku.需要locale至zh_CN,代替zh-CN 我认为这是由于在application.rb于,config.i18n.default_locale默认接受值这是Symbol, 而当我 ...

  2. apk反编译工具-apktool

    apk很easy被反编译,关于这篇文章apktool反编译工具. (一)优势反编译 1.能学习别人优秀代码 看看优秀apk他们的string.color命名规则,看看布局排版等都能学习到东西. 2.进 ...

  3. SQL Server 数据库没有有效全部者的三种解决的方法

    问题:     开发的过程中,操作系统出了问题.决定重装系统.可是没有将SQL Server中的数据库文件分离出来,直接将系统格了.在新系统数据库中附加了数据库文件,一切还算正常.但当打开数据库关系图 ...

  4. chrome扩展第三方浏览器下载安装

    1.使用其他浏览器打开谷歌应用市场,复制扩展详情地址url 2. 粘贴到:http://chrome-extension-downloader.com/中进行扩展的下载. 3. 拖拽到chrome e ...

  5. 它们的定义ListView,实现Item除去滑动和滑出菜单效果

    这个程序是基于变化从网上开源项目,详情货源忘记.懒得去搜索,.假设有不合适的地方.请与我联系作者.我会及时回复和处理! 序中主要包括两个ListView,一个是实现側滑删除.一个是側滑出菜单,代码中的 ...

  6. ASP.NET MVC上传文件----uploadify的使用

    课程设计需要实现上传文件模块,本来ASP.NET是有内置的控件,但是ASP.NET MVC没有,所以就有两种方法:自定义和采用第三方插件.由于时间的关系,故采用第三方插件:uploadify. upl ...

  7. Matlab基于学习------------------函数微分学

    <span style="font-size:18px;">% 函数微分学 % 函数微分学难比功能区,中的积分函数的性质整体叙述性说明.在某些时候差描述叙事的斜率功能 ...

  8. HDU4405-Aeroplane chess(可能性DP需求预期)

    Aeroplane chess Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  9. CSharp设计模式读书笔记(7):适配器模式(学习难度:★★☆☆☆,使用频率:★★★★☆)

    适配器模式(Adapter Pattern):将一个接口转换成客户希望的另一个接口,使接口不兼容的那些类可以一起工作,其别名为包装器(Wrapper).适配器模式既可以作为类结构型模式,也可以作为对象 ...

  10. 在面对变化,撇开NO

    参观后转到供应商,看到自己的生产线流水线半自己的钣金生产线举措.这就是我一直想厂提高生产现场的想法,因为通常当我看到工作人员努力工作和繁忙的生产,只见废现场,线解决方式时,有点莫名的兴奋. 幸亏是一家 ...