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!

人工智能实验室
相关文章相关文章
  • 未来两年人工智能要怎么走?看这篇就够了

    未来两年人工智能要怎么走?看这篇就够了

  • 无人驾驶汽车如何改变城市生活?听听他们怎么说

    无人驾驶汽车如何改变城市生活?听听他们怎么说

  • 韩春雨称已能重复实验结果 近期将有消息公布

    韩春雨称已能重复实验结果 近期将有消息公布

  • 英国研发“杀生”机器人 通过生命体获取能量

    英国研发“杀生”机器人 通过生命体获取能量

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

据国外媒体报道,在过去两年内,聊天机器人(chatbot)、人工智能以及机器学习的研发和采用取得了巨大进展。许多初创公司正利用人工智能和...

霍金 视觉中国 图 英国著名物理学家霍金(Stephen Hawking)再次就人工智能(AI)发声,他认为:对于人类来说,强大AI的出现可能是最美妙的...

文|郑娟娟 今年,人工智能(AI) 60岁了。在AI60岁的时候,笔者想要介绍一下AI100,一个刚刚2岁的研究项目,但它的预设寿命是100年,甚至更长...

AlphaGo与李世石的人机大战,为大众迅速普及了人工智能的概念。 但对谷歌而言,除了下围棋,现在的人工智能进展到哪一步了?未来,人工智能...