dojo中模块的定义与使用

2023-12-06 23:08
文章标签 模块 使用 定义 dojo

本文主要是介绍dojo中模块的定义与使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

异步模块定义(AMD)格式是Dojo从Dojo 1.7开始采用的模块格式。它提供了许多传统Dojo模块样式的增强功能,包括完全异步操作,真正的程序包可移植性,更好的依赖关系管理以及改进的调试支持。它也是一个社区驱动的标准,这意味着编写到AMD规范的模块可以与任何其他符合AMD的加载器或库一起使用。

1 什么是模块

模块是可由单个引用访问的值。如果要在模块中公开多个数据或函数,则它们必须是表示模块的单个对象的属性。使用模块对模块化编码更有意义,将代码拆分为逻辑子集以处理特定功能。

2 创建模块

使用AMD,可以通过注册到加载程序的方式来创建模块。加载器就是处理定义和加载模块背后逻辑的代码。加载器定义了与之交互的函数:requiredefine
全局函数define中使用加载器注册模块。

2.1 语法

define函数接受以下参数:
moduleId(可选,默认=未定义):模块标识符。此参数主要是早期AMD加载器的历史工件或支持AMD之前的Dojo,不应提供。
dependencies(optional,default = []):模块标识符的数组,它们是模块的依赖项。如果已指定,将在评估模块之前解析这些模块,并将它们作为参数按顺序传递给工厂函数。
factory:模块的值,或“factory”函数返回值

2.2 示例

define(function(){var privateValue = 0;return {increment: function(){privateValue++;},decrement: function(){privateValue--;},getValue: function(){return privateValue;}};
});

此代码使用闭包来创建外部代码无法直接访问的私有值,但可以通过作为模块值返回的对象上提供的方法进行检查和操作。

定义的模块是对对象的引用,而不是构造函数 - 这意味着加载此模块的每一段代码都将获得对完全相同对象的引用。通常,模块返回构造函数,但在某些情况下,返回单个对象是合适的。

3 配置加载程序

要利用AMD,首先需要显式配置加载程序以异步方式运行。这是通过将async配置属性设置为true

<script data-dojo-config="async: true" src="dojo1.13.0/dojo.js"></script>

而我们必须在加载dojo.js文件之前设置dojoConfig变量。

<script>var dojoConfig = {baseUrl: "",tlmSiblingOfDojo: false,packages: [{ name: "dojo", location: "dojo1.13.0/dojo" },{ name: "dijit", location: "dojo1.13.0/dijit" },{ name: "dojox", location: "dojo1.13.0/dojox" },{ name: "resources", location: "dojo1.13.0/resources"}]};
</script>
<script src="dojo1.13.0/dojo/dojo.js" data-dojo-config="async: true"></script>
  • baseUrl:定义加载包的基本URL,默认dojo.js文件夹的路径。
  • tlmSiblingOfDojo:默认情况下,加载程序期望在文件夹中找到模块,这些模块是加载加载器的文件夹的兄弟文件夹(即存放dojo.js文件文件夹的兄弟文件夹)。默认值为true
  • packages:包配置对象的数组。在最基础的层面上,包只是模块的集合。dojodijitdojox都是包的例子。然而,与目录中的简单模块集合不同,软件包充满了一些额外的功能,这些功能显着增强了模块的可移植性和易用性。便携式包是独立的,也可以通过cpm等工具安装。包配置允许您指定:
    1. name:包的名称。这应该与包含模块的文件夹的名称匹配。
    2. location:包裹的位置; 可以是其路径相对baseUrl 或绝对路径。
    3. main(可选,默认= main.js):用于在有人试图要求包本身时加载的正确模块。

4 加载模块

要加载模块,首先需要某种方法来识别它。与其他编程语言的模块/包系统类似,AMD模块由其路径和文件名标识。
将前面的代码保存在resource文件夹下,名字为counter.js。文件目录结构如下:

/index.html/dojo1.13.0//dijit//dojo//dojox//themes//resources/counter.js

使用require([ "resources/counter"])语句来加载模块。

require函数接受以下参数:
configuration(optional,default=undefined):具有加载程序配置选项的对象 - 这允许您在运行时重新配置加载程序。
dependencies(optional,default = []):模块标识符数组。如果指定,则在评估代码之前将解析这些模块。它们将按列出的顺序加载,并作为参数传递给回调函数,也按顺序传递。
callback:包含要运行的代码的函数,该代码取决于中的模块dependencies。您需要将代码包装在回调函数中,以支持异步加载并能够使用对模块的非全局引用。

index页面如下所示:

<html><body><script>var dojoConfig = {baseUrl: "",tlmSiblingOfDojo: false,packages: [{ name: "dojo", location: "dojo1.13.0/dojo" },{ name: "dijit", location: "dojo1.13.0/dijit" },{ name: "dojox", location: "dojo1.13.0/dojox" },{ name: "resources", location: "dojo1.13.0/resources"}]};</script><script src="dojo1.13.0/dojo/dojo.js" data-dojo-config="async: true"></script><script>require(["resources/counter"], function(counter){log(counter.getValue());counter.increment();log(counter.getValue());counter.decrement();log(counter.getValue());});</script></body>
</html>

如果需要对模块的引用,则需要提供回调函数。加载器将确保模块已加载,一旦加载,它将调用回调函数将任何模块作为参数传递给它。与任何其他函数一样,可以随意命名参数:不要求参数名称与模块名称有任何关系。这就是说,使用类似名称的模块名称很好的做法。本例中require中的第二个参数function即是回调函数,该回调函数中的参数为counter,取了和模块相同的名字。

5 模块加载模块

当应用程序由组织良好的模块组成时,模块之间自然存在很多依赖关系。define函数可以自动加载模块的依赖项,我们只需要将依赖项列表传递到define模块值之前。例如:

define(["dojo/_base/declare","dojo/dom","app/dateFormatter"
], function(declare, dom, dateFormatter){return declare(null, {showDate: function(id, date){dom.byId(id).innerHTML = dateFormatter.format(date);}});
});
  1. 多个依赖项:依赖项列表中指定了“dojo/dom”和(假设的)“app/dateFormatter”模块。
  2. 返回一个构造函数 。

这篇关于dojo中模块的定义与使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/463691

相关文章

详解Vue如何使用xlsx库导出Excel文件

《详解Vue如何使用xlsx库导出Excel文件》第三方库xlsx提供了强大的功能来处理Excel文件,它可以简化导出Excel文件这个过程,本文将为大家详细介绍一下它的具体使用,需要的小伙伴可以了解... 目录1. 安装依赖2. 创建vue组件3. 解释代码在Vue.js项目中导出Excel文件,使用第三

Linux alias的三种使用场景方式

《Linuxalias的三种使用场景方式》文章介绍了Linux中`alias`命令的三种使用场景:临时别名、用户级别别名和系统级别别名,临时别名仅在当前终端有效,用户级别别名在当前用户下所有终端有效... 目录linux alias三种使用场景一次性适用于当前用户全局生效,所有用户都可调用删除总结Linux

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

Mysql虚拟列的使用场景

《Mysql虚拟列的使用场景》MySQL虚拟列是一种在查询时动态生成的特殊列,它不占用存储空间,可以提高查询效率和数据处理便利性,本文给大家介绍Mysql虚拟列的相关知识,感兴趣的朋友一起看看吧... 目录1. 介绍mysql虚拟列1.1 定义和作用1.2 虚拟列与普通列的区别2. MySQL虚拟列的类型2

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

关于@MapperScan和@ComponentScan的使用问题

《关于@MapperScan和@ComponentScan的使用问题》文章介绍了在使用`@MapperScan`和`@ComponentScan`时可能会遇到的包扫描冲突问题,并提供了解决方法,同时,... 目录@MapperScan和@ComponentScan的使用问题报错如下原因解决办法课外拓展总结@

mysql数据库分区的使用

《mysql数据库分区的使用》MySQL分区技术通过将大表分割成多个较小片段,提高查询性能、管理效率和数据存储效率,本文就来介绍一下mysql数据库分区的使用,感兴趣的可以了解一下... 目录【一】分区的基本概念【1】物理存储与逻辑分割【2】查询性能提升【3】数据管理与维护【4】扩展性与并行处理【二】分区的

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存