BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

Mozilla Sweet.js:用宏扩展JavaScript

| 作者 Abel Avram 关注 11 他的粉丝 ,译者 雷慈祥 关注 1 他的粉丝 发布于 2012年10月24日. 估计阅读时间: 4 分钟 | QCon上海2018 关注大数据平台技术选型、搭建、系统迁移和优化的经验。

Mozilla Sweet.js使开发人员能够通过使用宏在语言中添加新的语法以丰富JavaScript。这有助于开发者们为自己的风格定制JavaScript语法,或是为他们的空白领域,创建基于JavaScript的领域专用语言来扩展JavaScript。

受到Scheme和Rust的启发,Sweet.js使我们可以使用macro关键字定义卫生宏。这个例子用更简短的def替换了function关键字:

macro def {
  case $name:ident $params $body => {
    function $name $params $body
  }
}

现在,能够用def来定义函数了:

def add (a, b) {
  return a + b;
}

另一个更为有趣的示例介绍了class关键字:

macro class {
  case $className:ident { 
    constructor $constParam $constBody
    $($methodName:ident $methodParam $methodBody) ... } => {

    function $className $constParam $constBody

    $($className.prototype.$methodName 
      = function $methodName $methodParam $methodBody; ) ...
  }
}

class使用示例:

class Person {
  constructor(name) {
    this.name = name;
  }

  say(msg) {
    console.log(this.name + " says: " + msg);
  }
}
var bob = new Person("Bob");
bob.say("Macros are sweet!");

更多宏相关示例可在GitHub上Mozilla/Sweet.js项目的wiki中找到,那里还能下到基于BSD许可证的源代码

包含宏的Sweet.js文件将通过sjs编译成纯JavaScript文件,无需使用任何额外的语法。require-sweet提供了AMD加载器SweetJS gem用于从Ruby编译Sweet.js文件。

Sweet.js目前支持声明式的宏定义,然而据Mozilla研究所的Tim Disney所说,计划将要支持命令式的定义。这意味着宏可以包含编译时运行的任意JavaScript代码。

查看英文原文Mozilla Sweet.js: Extending JavaScript with Macros


感谢崔康对本文的审校。

给InfoQ中文站投稿或者参与内容翻译工作,请邮件至editors@cn.infoq.com。也欢迎大家通过新浪微博(@InfoQ)或者腾讯微博(@InfoQ)关注我们,并与我们的编辑和其他读者朋友交流。

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

“用def替换function”。。。 by 所 无

你用def替换function,我用fun,他用xxx,这么写,代码会不会更乱,相互之间都读不懂对方的东西

Re: “用def替换function”。。。 by 雷 慈祥

Sweet.js只是提供了javascript的一种扩展机制,使代码能够相对简洁,干净,易于理解,这些代码最终还是会生成纯javascript脚本。
可以写出
Person boy=new Person();
boy.sayHello();
这样类型类似的代码,
而不是直接写成
console.log("sayhello");

可能比喻不是很贴切,呵呵。

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

2 讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT