美文网首页Scala编程与实践Web前端之路程序员
<More than React>异步编程真的好吗?

<More than React>异步编程真的好吗?

作者: ThoughtWorks | 来源:发表于2017-02-07 16:07 被阅读89次

    文/杨博

    本文首发于InfoQ:http://www.infoq.com/cn/articles/more-than-react-part05

    《More than React》系列的上一篇文章《HTML也可以编译?》介绍了 Binding.scala 如何在渲染 HTML 时静态检查语法错误和语义错误,从而避免 bug ,写出更健壮的代码。本篇文章将讨论Binding.scala和其他前端框架如何向服务器发送请求并在页面显示。

    在过去的前端开发中,向服务器请求数据需要使用异步编程技术。异步编程的概念很简单,指在进行 I/O 操作时,不阻塞当前执行流,而通过回调函数处理 I/O 的结果。不幸的是,这个概念虽然简单,但用起来很麻烦,如果错用会导致 bug 丛生,就算小心翼翼的处理各种异步事件,也会导致程序变得复杂、更难维护。

    Binding.scala 可以用 I/O 状态的绑定代替异步编程,从而让程序又简单又好读,对业务人员也更友好。

    我将以一个从 Github 加载头像的 DEMO 页面为例,说明为什么异步编程会导致代码变复杂,以及 Binding.scala 如何解决这个问题。

    DEMO 功能需求

    作为 DEMO 使用者,打开页面后会看到一个文本框。

    在文本框中输入任意 Github 用户名,在文本框下方就会显示用户名对应的头像。

    表格.png

    这五篇文章介绍了用 ReactJS 实现复杂交互的前端项目的几个难点,以及 Binding.scala 如何解决这些难点,包括:

    • 复用性
    • 性能和精确性
    • HTML模板
    • 异步编程

    除了上述四个方面以外,ReactJS 的状态管理也是老大难问题,如果引入 Redux 或者 react-router 这样的第三方库来处理状态,会导致架构变复杂,分层变多,代码绕来绕去。而Binding.scala 可以用和页面渲染一样的数据绑定机制描述复杂的状态,不需要任何第三方库,就能提供服务器通信、状态管理和网址分发的功能。

    如果你正参与复杂的前端项目,使用ReactJS或其他开发框架时,感到痛苦不堪,你可以用Binding.scala一举解决这些问题。Binding.scala快速上手指南中包含了从零开始创建Binding.scala项目的每一步骤。

    后记

    Everybody's Got to Learn How to Code
    ——奥巴马

    编程语言是人和电脑对话的语言。对掌握编程语言的人来说,电脑就是他们大脑的延伸,也是他们身体的一部分。所以,不会编程的人就像是失去翅膀的天使。

    电脑程序是很神奇的存在,它可以运行,会看、会听、会说话,就像生命一样。会编程的人就像在创造生命一样,干的是上帝的工作。

    我有一个梦想,梦想编程可以像说话、写字一样的基础技能,被每个人都掌握。

    如果网页设计师掌握Binding.scala,他们不再需要找工程师实现他们的设计,而只需要在自己的设计稿原型上增加魔法符号.bind,就能创造出会动的网页。

    如果QA、BA或产品经理掌握Binding.scala,他们写下验收标准后,不再需要检查程序员干的活对不对,而可以把验收标准自动变成可以运转的功能。

    我努力在Binding.scala的设计中消除不必要的技术细节,让人使用Binding.scala时,只需要关注他想传递给电脑的信息。

    Binding.scala是我朝着梦想迈进的小小产物。我希望它不光是前端工程师手中的利器,也能成为普通人迈入编程殿堂的踏脚石。

    相关链接


    More than React系列文章:

    More than React(一)为什么ReactJS不适合复杂的前端项目?

    More than React(二)React.Component损害了复用性?

    More than React(三)虚拟DOM已死?

    More than React(四)HTML也可以静态编译?

    More than React(五)异步编程真的好吗?

    相关文章

      网友评论

        本文标题:<More than React>异步编程真的好吗?

        本文链接:https://www.haomeiwen.com/subject/nhhmittx.html