javascript中Require调用js的实例

  次阅读 来源:互联网(转载协议) 2016-03-24 20:12 我要评论(0)

无组织的函数们

在我最初开始写JavaScript 函数时,通常是这样的:

代码如下

functionfun1() {

// some code here

}

functionfun2() {

// some other code here

}

...

函数全写在全局环境中,项目很小时,通常不会有什么冲突问题。

代码多了后,渐渐就发现,函数名称(英文词汇)有点不够用了。于是引入命名空间的概念,开始模块化代码

命名空间下的函数

在命名空间下,我的代码这样写:

代码如下

varcom = com || {};

com.zfanw= com.zfanw || {};

com.zfanw.module1= (function() {

// some code here

return {

func1: func1,

...

};

}());

com.zfanw.module2= (function() {

// some other code here

return {

func1: func1,

...

};

}());

...

本着要面向对象的原则,执行函数通常我要这么写的:

com.zfanw.module1.func1.apply({},['arg1',arg2]);

...

当然,为了少打些字符,我还会在闭包中导入1公共API 接口:www.45it.com

代码如下

(function($,mod1) {

// some code here

mod1.func1.apply({},['arg1',arg2]);

}(jQuery,com.zfanw.module1));

...

至此,代码冲突的可能性已经很小,但代码依赖的问题,多脚本文件管理、阻塞的问题,渐渐浮出水面– 命名空间的办法开始捉急。

于是Require.js2 出常

Require.js

首先了解下require.js 里模块的概念3:

A module is different from a traditional script file in that it defines awell-scoped object that avoids polluting the global namespace. It can explicitlylist its dependencies and get a handle on those dependencies without needing torefer to global objects, but instead receive the dependencies as arguments tothe function that defines the module.

简单地说,有两点,一、模块作用域自成一体,不污染全局空间;二、模块指明依赖关系,并且依赖是通过参数传递的形式导入的,无需通过全局对象引用– 依赖同样不污染全局空间。

定义模块

与上面的老长的命名空间方式不同,require.js用全局方法 define 来定义模块,形式如下:

代码如下

define(id?,dependencies?, factory); // ? 表示可选项

我且把模块分两种。

无依赖的模块

假如一个模块并不依赖其他模块,那么定义起来是很简单的,比如模块hello 放在 hello.js 文件中:

代码如下

本站部分文章来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 品友互动为Digital Travel APAC2018 唯一受邀中国AI企业

    品友互动为Digital Travel APAC2018 唯一受邀中国AI企业

  • 让AI触手可及  Qualcomm携手创通联达推出全新终端侧AI开发套件

    让AI触手可及 Qualcomm携手创通联达推出全新终端侧AI开发套件

  • 第一批国家重点研发计划公布,旷视科技开启“五年行动”

    第一批国家重点研发计划公布,旷视科技开启“五年行动”

  • 长虹新款智能语音空调,告诉你空调也能玩Siri

    长虹新款智能语音空调,告诉你空调也能玩Siri

网友点评网友点评
阅读推荐阅读推荐

据外媒报道,STEER打造了首款完全自动驾驶停车技术,旨在使常规车辆转变为无人驾驶车辆。STEER的首款技术应用是4级自动驾驶及网络安全停车...

近日,美国软性机器抓手制造商 Soft Robotics 宣布,获得 2000 万美元的融资,本轮投资者包括 Scale Venture Partners,Calibrate Ventures...

据外媒报道,加州车管局发布了《2017自动驾驶脱离报告(California Autonomous Vehicle Disengagement Reports)》,其中谈及了脱离的具体...

用人机语音交互,来解决智能家居适老的问题;通过家庭门禁与安防套件、空气净化套件、可燃气体与有害气体监控套件等相互联动,在不同生活情...