Node.js开发实战 记录一次模块风格在浏览器中的尝试
小作 2018-02-02 来源 :网络 阅读 573 评论 0

摘要:Node.js有一套简洁的格式写模块,它遵循的就是 Moudles。在Node.js开发实战中,在浏览器中中尝试模块风格会怎么样呢?


Node.js有一套简洁的格式写模块,它遵循的就是 Moudles。在Node.js开发实战中,在浏览器中中尝试模块风格会怎么样呢?


浏览器里的JavaScript呢? 尽管语言本身暂不支持模块(ES6打算支持),但可以用现有的 API 包装一个写法出来。毫无疑问,首先想到的是Node.js的 Modules 格式,它是最好的效仿对象。因为前后端有一个统一的方式写JS模块岂不乐哉!

 

但一开始就碰到一些难题

1.服务器端JS模块文件就在本地,浏览器端则需要通过网络请求。

2.服务器端可以很容易的实现同步或异步请求模块,浏览器端则问题多多。

 

如下

var event = require("event");
 
event.bind(el, 'click', function() {
    // todo
});

这段代码中 require 如果是异步执行的,则 event.bind 的执行有可能会出错。

 

那实现同步的 require 不就行了吗? 

 

的确可以使用 XHR 实现同步载入模块JS文件。但XHR的缺点也是明显的,它不能跨域,这点让人很难接受,因为有些场景需要模块部署在不同的服务器。

 

那只能通过 script tag 来实现模块加载了!

 

但 script tag 默认就是异步的,要实现 Node.js 的一模一样风格(Modules)很难,几乎是不可能。

 

这时,“救世主”出现了:Modules/Wrappings ,顾名思义包裹的模块。该规范约定如下

定义模块用module变量,它有一个方法declare

1.declare接受一个函数类型的参数,如称为factory

2.factory有三个参数分别为require、exports、module

3.factory使用返回值和exports导出API

4.factory如果是对象类型,则将该对象作为模块输出

 

描述有拗口,代码却很简单,使用了一个 function 包裹模块(Node.js 模块则无需包裹)。

 

一个基本的模块定义

module.declare(function(require, exports, module)
{
    exports.foo = "bar";
});

直接使用对象作为模块

module.declare(
{
    foo: "bar"
});

Modules/Wrappings 的出现使得浏览器中实现它变得可能,包裹的函数作为回调。即使用 script tag 作为模块加载器,script 完全下载后去回调,回调中进行模块定义。

 

好了,截止目前我们已经看到了两种风格的模块定义:Modules 和 Modules/Wrappings。

CommonJS Modules有1.0、1.1、1.1.1三个版本。

 

Node.js、SproutCore实现了 Modules 1.0。

SeaJS、AvocadoDB、CouchDB等实现了Modules 1.1.1。

SeaJS、FlyScript实现了Modules/Wrappings。

 

注:

SeaJS未实现全部的 Modules 1.1.1,如require函数的main,paths属性在SeaJS中没有。但 SeaJS 给require添加了async、resolve、load、constructor

SeaJS没有使用 Modules/Wrappings 中的module.declare定义模块,而是使用define函数(看起来象 AMD 中的 define,实则不然)


你也可以亲自尝试一下Node.js模块风格在浏览器中哦。总之,同学们,你想要的职坐标IT频道都能找到!


本文由 @小作 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程