dojo Quick Start/dojo入门手册--package机制

简介:

说完了dojo里的类继承机制,不得不说说package机制。

主要用到的有 
dojo.require 
dojo.provide 
dojo.registerModulePath

dojo.require

dojo.require就是引入相应路径文件下的js文件,现在已经有很多library这样做了。现在我们假设要用project/dojo-lib/dojo/string.js

dojo中的顶层目录就是dojo.js所在目录的上一层,即"project/dojo-lib/",而dojo.js放在project/dojo-lib/dojo/dojo.js 所以我们就这样:

dojo.require("dojo.string");

比如要引用其他目录下的:

project/dojo-lib/dojox/dtl/_base.js,则这样:dojo.require("dojox.dtl._base"); project/dojo-lib/dojox/grid/Grid.js dojo.require("dojox.grid.Grid");

说白了,就和ruby之类的require很相似。

dojo.provide

要自己编写一个package怎么办,那就利用dojo.provide。比如要写在:project/dojo-lib/com/javaeye/fyting/Package1.js 那么在对应的Package1.js中第一行需要这样写:

dojo.provide("com.javaeye.fyting.Package1");

类似java里的package声明,是吧?

dojo.registerModulePath

那要是我写的js文件不想和dojo放在一起怎么办呢,那就用registerModulePath。假设要放在:

project/js/com/javaeye/fyting/Package2.js

Package2.js和上面的Package1.js一样的写法,不需要作特殊变化,就这样就行:

dojo.provide("com.javaeye.fyting.Package2");

在使用时,需要指名这个Package2.js所在的位置, 
dojo.registerModulePath("com","http://www.cnblogs.com/js/com"); 
只需要注意这里的相对路径是相对dojo.js来的。

我们假设所有以com.javaeye开头的js都放在一起,而com.microsoft的放在另外的地方,为了防止冲突,可以这样: 
dojo.registerModulePath("com.javaeye","http://www.cnblogs.com/js/com/javaeye"); 
dojo.registerModulePath("com.microsoft","http://www.cnblogs.com/javascript/com/microsoft");

总得来说,package机制是开发大型项目必须的,但是造成了调试困难,使用dojo.require引入js出错时,根本不知道是什么原因,所以调试时最好手动引入js,dojo的test也是这么搞的。还有js框架中的各种实现类继承的手法,也造成调试困难,dojo还随地抛出个Error,又缺少java那样的error statck,根本不知道错误根源在哪儿。所以,期待js原生地支持这些。



本文转自左正博客园博客,原文链接:http://www.cnblogs.com/soundcode/archive/2011/07/26/2117562.html,如需转载请自行联系原作者

目录
相关文章
|
24天前
|
自然语言处理 编译器 C语言
【C++ 20 新特性】参数包初始化捕获的魅力 (“pack init-capture“ in C++20: A Deep Dive)
【C++ 20 新特性】参数包初始化捕获的魅力 (“pack init-capture“ in C++20: A Deep Dive)
37 0
|
前端开发
前端学习案例2-common.js原理部分2
前端学习案例2-common.js原理部分2
48 0
前端学习案例2-common.js原理部分2
|
前端开发
前端学习案例1-common.js原理部分1
前端学习案例1-common.js原理部分1
44 0
前端学习案例1-common.js原理部分1
|
JavaScript
js基础笔记学习170-call和apply2
js基础笔记学习170-call和apply2
52 0
js基础笔记学习170-call和apply2
|
JavaScript
js基础笔记学习169-call和apply1
js基础笔记学习169-call和apply1
34 0
js基础笔记学习169-call和apply1
|
存储 JavaScript 前端开发
企业级项目开发中的交互式解释器以及global全局定义、Stream流的合理运用和实战【Note.js】
企业级项目开发中的交互式解释器以及global全局定义、Stream流的合理运用和实战【Note.js】
|
Python
Selenium Python 框架之 BasePage页面封装写法
Selenium Python 框架之 BasePage页面封装写法
336 0
|
前端开发 JavaScript
Promise.all() 原理解析及使用指南
Promise 对象是ECMAScript 6中新增的对象,主要将 JavaScript 中的异步处理对象和处理规则进行了规范化。前面介绍了《Promise.any() 原理解析及使用指南》,本文来介绍另一个方法 Promise.all(promises) ,能够一次并行处理多个 promise,并且只返回一个 promise 实例, 那个输入的所有 promise 的 resolve 回调的结果是一个数组。
595 0
Promise.all() 原理解析及使用指南
|
前端开发
Promise.any() 原理解析及使用指南
Promise.any(promises) 是 ES2021 新增的特性,它能够并行运行 promise,并解析为 promises 列表中第一个成功解析的 promise 的值。需要注意的是 Promise.any() 方法依然是实验性的,尚未被所有的浏览器完全支持。
395 0
Promise.any() 原理解析及使用指南
|
监控 NoSQL JavaScript
Java和Node.js实战 MongoDB 4.x 新特性:Change Streams 变化流
MongoDB 4.0 Change Streams增强新特性,我们可以跟踪单个集合Colletion、数据库或部署集群的数据库和集合中的所有变化。
2503 0