设为首页 收藏本站
查看: 730|回复: 0

[经验分享] NodeJS模块格式在浏览器中的尝试

[复制链接]

尚未签到

发表于 2017-2-22 07:56:10 | 显示全部楼层 |阅读模式
  我们知道NodeJS有一套简洁的格式写模块,它遵循的就是 Moudles

  浏览器里的JavaScript呢? 尽管语言本身暂不支持模块,但可以用现有的API包装一个写法出来。
  毫无疑问,首先想到的是NodeJS的module格式
,它是最好的效仿对象。因为前后端有一个统一的方式写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默认就是异步
的,要实现NodeJS的一模一样风格(Modules
)问题多多,几乎是不可能。
  这时,又一模块格式出现了:Modules/Wrappings
 (还有AMD
),顾名思义包裹的模块。该规范约定如下
  1,定义模块用module变量,它有一个方法declare
  2,declare接受一个函数类型的参数,如称为factory
  3,factory有三个参数分别为require、exports、module
  4,factory使用返回值和exports导出API
  5,factory如果是对象类型,则将该对象作为模块输出
  描述有拗口,代码却很简单,使用了一个function包裹模块(NodeJS模块则无需包裹)。
  一个基本的模块定义

module.declare(function(require, exports, module)
{
exports.foo = "bar";
});
  一个使用返回值的模块定义

module.declare(function(require)
{
return { foo: "bar" };
});
  直接使用对象作为模块

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

  Modules/Wrappings
的出现使得浏览器中实现它变得可能,包裹的函数作为回调。即使用script tag作为模块加载器,script完全下载后去回调,回调中进行模块定义。
  好了,截止目前我们已经看到了两种风格的模块定义:Modules
和  Modules/Wrappings

  CommonJS Modules有1.0、1.1、1.1.1三个版本。
  NodeJS、SproutCore
实现了 Modules 1.0

  SeaJS
、AvocadoDB、CouchDB等实现了Modules 1.1.1

  SeaJS、FlyScript
实现了Modules/Wrappings。
  注:
  1,SeaJS未实现全部的 Modules 1.1.1。如require函数的main,paths属性在SeaJS中没有。但SeaJS给require添加了async、resolve、load、constructor。
  2,SeaJS没有使用 Modules/Wrappings 中的module.declare定义模块,而是使用define函数。
  相关:
  script loaders

  AMD:浏览器中的模块规范

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-345399-1-1.html 上篇帖子: nodejs+phonegap+ionic环境搭建并创建项目 下篇帖子: 【NodeCC】NodeJs开发的脚本压缩和combo工具
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表