seajs中模块依赖的加载处理实例分析

前端之家收集整理的这篇文章主要介绍了seajs中模块依赖的加载处理实例分析前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

@H_301_0@本文实例讲述了seajs中模块依赖的加载处理。分享给大家供大家参考,具体如下:


@H_3010@最近在做项目的时候发现一些关于模块依赖问题,特记录下:


@H
301_0@比如现有3个文件


<div class="jb51code">
<pre class="brush:js;">
/init.js/
define(function(require,exports,module){
require('jquery');
require('jquery.plugA');
})
/jquery.plugA.js/
define(function(require,module){
require('jquery');
require('jquery.plugB');
//code...
})
/jquery.plugB.js/
define(functioin(require,module){
require('jquery');
//code...
})

@H_301_0@比如执行init.js时,init.js、jquery.plugA.js、jquery.plugB.js都会依赖到jquery,那么这种情况下seajs对jquery如何处理的呢?只执行一次?执行多次?还是其他方式?

@H_301_0@

此处参考玉伯的回答:

@H_301_0@我对模块调用的理解是,调用是指获取某个模块的接口。在 SeaJS 里,调用,比如: var a = require('./a') 在执行 require(‘./a') 时,会获取模块的接口,如果是第一次调用,会初始化模块 a,以后再调用时,直接返回模块 a 的接口; define 只是注册模块信息,比如打包之后:define(id,deps,factory)注册了一个模块到 seajs.cache 中,define 类似:seajs.cache[id] = { id: id,dependencies: deps,factory: factory }

@H_301_0@是纯注册信息。

@H_301_0@而 require('./a') 时,才会执行 seajs.cache['a'].factory,执行后得到 seajs.cache['a'].exports

@H_301_0@扩展:URI与URL的区别

@H_301_0@URI:Uniform Resource Identifiers ,统一资源标识符;

@H_301_0@URL:Uniform Resource Locators ,统一资源定位符;

@H_301_0@URN:Uniform Resource Names,统一资源名称

@H_301_0@URL,URN是URI的子集.

@H_301_0@参考

@H_301_0@Module.STATUS的具体含义:https://github.com/seajs/seajs/issues/303 分清 URI、URL 和 URNhttp://www.ibm.com/developerworks/cn/xml/x-urlni.html

@H_301_0@更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》及《

@H_
301_0@希望本文所述对大家JavaScript程序设计有所帮助。

猜你在找的JavaScript相关文章