NVIDIA 初创加速计划,免费加速您的创业启动 了解详情
写点什么

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:121994
    用户头像

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

    关注

    评论

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

    架构师训练营第12周课后练习

    脸不大

    大数据

    架构师训练营 -week12-总结

    大刘

    极客大学架构师训练营

    北海游记:日出、日落与海鲜

    北风

    摄影 游记 大海

    极客时间架构师训练营 1 期 - 第 12 周总结

    Kaven

    架构师训练营 1 期 -- 第十二周作业

    曾彪彪

    极客大学架构师训练营

    架构师训练营第 1 期 week12 总结

    张建亮

    极客大学架构师训练营

    极客时间架构师培训 1 期 - 第 12 周作业

    Kaven

    运维数字化

    春如夏花

    企业架构 DevOps 数字化运维

    week12作业

    龙卷风

    架构师一期

    架构师训练营第 12 周课后练习

    叶纪想

    极客大学架构师训练营

    Week8作业

    lggl

    架构师训练营第一期第十二周总结

    Leo乐

    极客大学架构师训练营

    组合设计模式实现绘图Pannel

    我们新四军不拿群众一针一线

    如何更简单的使用Polly

    八苦-瞿昙

    随笔杂谈 aop

    架构师训练营第一期第十二周作业

    Leo乐

    极客大学架构师训练营

    Week8总结

    lggl

    使用 Docker 部署 canal 服务,实现 MySQL 数据库 binlog 日志解析

    AlwaysBeta

    Python MySQL 数据库 Docker Binlog

    [架构师训练营第 1 期] 第12周学习总结

    猫切切切切切

    极客大学架构师训练营

    第十二周学习总结

    Meow

    LeetCode题解:433. 最小基因变化,DFS,JavaScript,详细注释

    Lee Chen

    算法 大前端 LeetCode

    Java Parser应用介绍

    maijun

    架构师训练营 1 期第 12 周:数据应用(一)- 总结

    piercebn

    极客大学架构师训练营

    架构师训练营第十二周作业

    月殇

    极客大学架构师训练营

    第十二周作业

    fmouse

    天下武功,唯“拆”不破之MECE原则二| 技术人应知的创新思维模型 (6)

    Alan

    个体成长 技术人应知的创新思维模型 28天写作

    架构师训练营第十二周总结

    月殇

    极客大学架构师训练营

    第十二周总结

    fmouse

    作业-第八周

    ray-arch

    架构师训练营第十二周作业

    Shunyi

    极客大学架构师训练营

    第十二周作业

    极客大学架构师训练营

    架構師訓練營 week12 總結

    ilake

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