首页 web前端 js教程 JS模块与命名空间的介绍_javascript技巧

JS模块与命名空间的介绍_javascript技巧

May 16, 2016 pm 05:39 PM
命名空间

起因
将代码组织到类中的一个重要原因是让代码更加“模块化”,可以在很多不同的场景中实现代码的重用。但类不是唯一的模块化代码的方式。

一般来讲,模块是一个独立的JS文件。模块文件可以包含一个类定义、一组相关类、一个实用函数库或者一些待执行的代码。

模块化的目标是支持大规模的程序开发,处理分散源中代码的组装,并且能让代码正确运行,哪怕包含了不需要的模块代码,也可以正确执行代码。

理想状态下,所有模块都不应当定义超过一个全局标识。

模块函数
通过把模块定义在某个函数的内部来实现,定义的变量和函数都属于该函数的局部变量,在函数外不可见。实际上,可以将这个函数作用域用做模块的命名空间(模块函数)

一旦将模块代码封装进一个函数中,就需要一些方法导出公用API,以便在模块函数外部调用它们。下面有几种方式导出公用API:

首先创建一个命名空间

复制代码 代码如下:

// 创建一个全局变量用来存放与学校相关的模块
var school;                // 创建school命名空间
if(!school) school = {};

1. 利用构造函数

复制代码 代码如下:

// 返回Student构造函数来导出公共API
school.Student = (function() {
    function Student() {

    }
    // ...... 定义Student的原型对象和私有属性和方法 ........
    return Student;        // 返回Student构造方法导出公共API
})();

2. 返回命名空间对象

如果模块API包括多个单元,则它可以返回命名空间对象

复制代码 代码如下:

// 为school添加students模块
school.students = (function() {
    // 这里定义了很多类如课程类/成绩类, 使用局部变量和函数
    function Subject() { /* ... */ }
    function Grade() { /* ... */ }

    // 通过返回命名空间对象将API导出
    return {
        Subject: Subject,
        Grade: Grade
    };
})();

3. 通过关键字new调用

另外一种类似类似技术:把模块函数当做构造函数,通过new来调用。把它们(公共API)赋值给this属性来将其导出

复制代码 代码如下:

school.students = (new function() {
    // ..... 这里省略了代码 ......

    // 将API导到this对象中
    this.Subject = Subject;
    this.Grade = Grade;

    // 注意,这里没有返回值
}());    // 括号写在里面。这里是创建新实例,new后面应紧跟构造函数的调用而不是表达式

4. 已定义命名空间对象

作为一种替代方案,如果已经定义了全局命名空间对象,通过模块函数可以直接设置那个对象的属性。

复制代码 代码如下:

// 如果已经定义了命名空间对象
var school;                // 创建school命名空间
if(!school) school = {};
school.students = {};    // student命名空间已经定义
(function(students) {
    // ..... 这里省略了代码 ......

    // 将公共API导到上面定义的命名空间中
    students.Subject = Subject;
    students.Grade = Grade;
    // 这里也不需要返回值
})(school.students);

为此,导出公共API的方式已经讲完。

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

仓库:如何复兴队友
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

解决PHP报错:未找到指定的命名空间类 解决PHP报错:未找到指定的命名空间类 Aug 18, 2023 pm 11:28 PM

解决PHP报错:未找到指定的命名空间类在使用PHP进行开发时,我们经常会遇到各种各样的报错信息。其中一种常见的报错就是“未找到指定的命名空间类”。这个错误通常是由于引入的类文件没有被正确地命名空间引用所引起的。本文将介绍如何解决这个问题,并提供一些代码示例。首先,让我们看一下一个常见的报错信息示例:Fatalerror:UncaughtError:C

如何在F3框架中使用命名空间(Namespace)? 如何在F3框架中使用命名空间(Namespace)? Jun 03, 2023 am 08:02 AM

F3框架是一款简单易用,灵活可扩展的PHPWeb框架,它的命名空间(Namespace)机制为我们提供了一个更加规范、可读性更强、代码结构更为清晰的编程方式。在这篇文章中,我们将探讨如何在F3框架中使用命名空间。一、什么是命名空间命名空间常被用于解决在PHP中命名冲突的问题,它可以将一个或多个类、函数或常量封装在一个命名空间中,相当于给它们加上一个前缀。例

Redis的命名空间和过期机制的设计思路和实现方式 Redis的命名空间和过期机制的设计思路和实现方式 May 11, 2023 am 10:40 AM

Redis是一个开源的高性能的键值存储数据库。在使用Redis进行数据存储的时候,我们需要考虑到键的命名空间与过期机制的设计,来维护Redis的性能和数据完整性。本文将介绍Redis的命名空间和过期机制的设计思路和实现方式。一、Redis的命名空间设计思路在Redis中,键是可以任意设置的。为了方便管理和区分不同的数据类型,Redis引入了命名空间的概念。命

C++语法错误:使用了未定义的命名空间,怎么处理? C++语法错误:使用了未定义的命名空间,怎么处理? Aug 21, 2023 pm 09:49 PM

C++是一种广泛使用的高级编程语言,它有很高的灵活性和可扩展性,但同时也需要开发者严格掌握其语法规则才能避免出现错误。其中,常见的错误之一就是“使用了未定义的命名空间”。本文将介绍该错误的含义、出现原因和解决方法。一、什么是使用了未定义的命名空间?在C++中,命名空间是一种组织可重用代码的方式,以便保持代码的模块性和可读性。使用命名空间的方式可以使同名的函数

PHP8新特性示例:如何利用命名空间和代码更好地组织代码结构? PHP8新特性示例:如何利用命名空间和代码更好地组织代码结构? Sep 11, 2023 pm 12:22 PM

PHP8新特性示例:如何利用命名空间和代码更好地组织代码结构?引言:PHP8是PHP编程语言的一个重要版本,它引入了许多令人兴奋的新特性和改进。其中一个最重要的新特性是命名空间(namespace)。命名空间是一种将代码组织成更好结构的方法,它能够避免相同名称的类、函数和常量之间的冲突。在本文中,我们将介绍如何利用命名空间和代码来更好地组织PHP8代码的结构

解决PHP命名空间错误并生成对应报错提示的方法 解决PHP命名空间错误并生成对应报错提示的方法 Aug 07, 2023 pm 05:16 PM

解决PHP命名空间错误并生成对应报错提示的方法PHP是一种广泛使用的服务器端脚本语言,被用于开发Web应用程序。在PHP中,命名空间(Namespace)是一种管理和组织代码的机制,可以避免命名冲突,提高代码的可读性和可维护性。然而,由于命名空间定义和使用的复杂性,有时会导致错误的产生。本文将介绍一些解决PHP命名空间错误并生成对应报错提示的方法。一、命名空

命名空间的奥德赛:探索 PHP 的模块化天堂 命名空间的奥德赛:探索 PHP 的模块化天堂 Mar 10, 2024 am 09:04 AM

命名空间:模块化天堂在软件开发中,可维护性是一个至关重要的因素。随着代码库的不断增长,组织和封装代码对于管理复杂性至关重要。PHP中的命名空间正是为此而生的。命名空间的概念命名空间是逻辑上相关的标识符的集合。它提供了一种将类、函数和常量组织到特定领域的机制。命名空间通过为每个实体提供一个唯一的名称来消除名称冲突,避免不同的类或函数具有相同的名称。命名空间的语法在php中,命名空间使用反斜杠()定义:namespaceMyProjectDatabase;上面的代码创建了一个名为"MyProject

PHP 5.4版本新功能:如何使用命名空间别名简化类名调用 PHP 5.4版本新功能:如何使用命名空间别名简化类名调用 Jul 29, 2023 pm 11:45 PM

PHP5.4版本新功能:如何使用命名空间别名简化类名调用在PHP5.3版本中引入的命名空间(namespace)功能为我们提供了一种更好的组织和管理代码的方式。通过将相关的类、函数和常量组织到命名空间中,可以有效避免不同模块之间的命名冲突。而在PHP5.4版本中,命名空间别名(namespacealias)的功能被引入,进一步方便了我们对类名的调用和

See all articles