写点什么

Meteor 0.8:发布全新的渲染系统 Blaze

  • 2014-04-14
  • 本文字数:1390 字

    阅读完需:约 5 分钟

Meteor 最近发布了 0.8 版本,该版本“对 Meteor 的渲染系统做了一次彻底的检查”。Meteor 的下一代实时模板引擎 Blaze 支持细粒度的 DOM 更新、jQuery 集成和更简单的 API。Blaze 替代了在 2012 年发布的 0.4 版本中所引入的实时页面更新引擎 Saprk。

Matt Debergalis 在 Meteor 的博客上将 Blaze 描述为“对开发者友好的”,同时它的架构比起 Spark 有几个方面的提升。

Blaze 包含两部分:第一部分是一个构建时编译器,它将模板转换成 JavaScript 代码。Spacebars——Handlebars 风格的编译器——将 HTML 模板转换成实时更新的 DOM 元素,用户能够编写普通样子的 HTML 模板和帮助器。

“当某个用户修改了数据或者某个模板依赖的新数据通过网络抵达的时候,Blaze 就会自动地更新你的屏幕,不需要声明任何依赖,也不需要编写管理应该如何更新屏幕的代码。”Debergalis

Blaze 的第二部分是运行时 API,它“渲染元素,跟踪元素的依赖,在元素的完整生命周期内随着依赖的变化更新元素”。

对之前 Spark API 的替代包括移除了Meteor.render,为定制块帮助器的定义引入了一个新模式。添加和废弃的API 列表包括UI.body 现在是与整个BODY 元素相关的一个模板。

Spacebars 解析器让用户能够做一些之前不能做的事情,例如:

  • HTML 感知更新。模板解析器现在会解析 HTML 元素,这让细粒度的响应更新成为可能,包括对 DOM 元素进行属性级的更新。
  • 预编译。Spacebars 编译器会生成调用内部 Meteor 接口的简单程序代码以便于在将来执行客户端或者服务器端的渲染工作。这比在运行时解释模板或者解析它的 HTML 输出更加有效。
  • 语法扩展。Handlebars 语法极小,我们预见随着时间的发展需要添加一些额外的、精选的扩展。我们还会实现 Handlebars 现在支持但是 Meteor 并不具备的顶层特性,例如支持对象,让你能够访问当前索引或者键的#each。

在 Meteor 0.8 中 Handlebars 命名空间已经被废弃。现在 Handlebars.SafeString 改成了 Spacebars.SafeString,而 Handlebars.registerHelper 则变成了 UI.registerHelper。

Spacebars 需要 HTML 是“格式良好的”。引用 Blaze 项目 GitHub 页面上的说明:“在 Spark 中 HTML 解析是通过浏览器完成的,这种方式更加宽容”。

另外,Blaze HTML 解析器目前还没有完全实现 HTML 规范。发布说明中还特别指出它并不会自动地关闭某些标签,例如

  • 。Meteor 社区非常欢迎 0.8 版本的发布。在 LinkedIn 网站上的 Meteor中,用户 Uğur Toprakdeviren 发起了一个讨论,他问道:“对于新版本的 Meteor(Blaze、Spacebars 等)你的观点是什么呢?”。

    Ongo Works 的创建者和 CTO Aaron Singmaster-Judd 回复说:“真了不起,做的好,感谢 Meteor 团队和在新代码库上工作的社区包开发者。”。

    “升级已有的包可能需要一些努力,而这也会导致 Web 上呈现出大量无效的信息,但是这是值得的。”

    Hacker News 上的用户对于该更新的反应也很不错。用户 elsherbini 对 jQuery 集成的评论是“jQuery 兼容的工作量非常巨大,赞一个!”。其他用户也分享了自己对 Blaze 的正面评价,TylerE 对编译器的评价是:“不得不说,我非常兴奋,因为现在终于可以按照一种非旁门左道的方式去使用 jade 模板了,对我而言这是重大的胜利。”。

    Debergalis 指出实时模板引擎是 0.8 版本中仅有的新特性,它向 Meteor 1.0 版本迈出了重要的一步。

    查看英文原文 Meteor 0.8: Blaze Release Overhauls Rendering System

  • 2014-04-14 02:122334
    用户头像

    发布了 321 篇内容, 共 126.7 次阅读, 收获喜欢 19 次。

    关注

    评论

    发布
    暂无评论
    发现更多内容

    解决Fragment多层嵌套时onActivityResult无法正确回调的问题

    android 程序员 移动开发

    详解-RxJava2-的线程切换原理

    android 程序员 移动开发

    【架构实战营作业】模块七——王者荣耀商城异地多活架构

    聆息

    自定义ViewGroup实现微信朋友圈九宫格图片控件

    android 程序员 移动开发

    记一次腾讯社招Android面试(已拿到offer入职)

    android 程序员 移动开发

    详解-RxJava2-的线程切换原理(1)

    android 程序员 移动开发

    C++学习路线图

    泰伦卢

    c++

    云计算市场,是时候来一场鱿鱼游戏了

    白洞计划

    致刚入行的小白,或者工作一到三年的Android程序员,如何规避“内卷

    android 程序员 移动开发

    认识ClassLoader

    android 程序员 移动开发

    自学Android,面试被怼,看我如何拿下阿里offer

    android 程序员 移动开发

    蒂花之秀---大神用漫画讲解字符串匹配算法,让你噩梦变美梦

    android 程序员 移动开发

    Linux基金会宣布成立NextArch Foundation基金会 第四范式成为首批共建单位

    第四范式开发者社区

    详解BAT面试必问之ThreadLocal(源码+内存)

    android 程序员 移动开发

    自定义View(一) Android 可计数EditText实现

    android 程序员 移动开发

    设计模式之行为型模式

    android 程序员 移动开发

    自定义Gradle插件的开发

    android 程序员 移动开发

    nginx 缓存大小的含义

    liuzhen007

    11月日更

    记联想公司的一次Android面试

    android 程序员 移动开发

    论一个APP从启动到主页面显示经历的过程?

    android 程序员 移动开发

    设计模式学习--观察者模式(Observer Pattern)

    android 程序员 移动开发

    腾讯校招被问Android网络相关面试题,精编参考解析全整理,你不看看吗?

    android 程序员 移动开发

    设计模式(行为型)之模板方法模式(Template Method Pattern)

    android 程序员 移动开发

    试用期没通过的原因,居然是被发现了上班偷偷干这事

    android 程序员 移动开发

    计算机编码简析(1)

    android 程序员 移动开发

    计算机编码简析

    android 程序员 移动开发

    腾讯大牛,一篇文章教你什么是Android-Fragment-,Android高级架构师筑基必备!

    android 程序员 移动开发

    自定义View

    android 程序员 移动开发

    裸辞两个月从Android转战web前端的求职之路

    android 程序员 移动开发

    要想工资涨得快,还是得跳槽?一个三本Android程序猿外包到阿里的逆袭之路

    android 程序员 移动开发

    模块三作业

    bob

    「架构实战营」

    Meteor 0.8:发布全新的渲染系统Blaze_JavaScript_James Chesters_InfoQ精选文章