首页 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脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

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

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1664
14
CakePHP 教程
1423
52
Laravel 教程
1317
25
PHP教程
1268
29
C# 教程
1246
24
解决PHP报错:未找到指定的命名空间类 解决PHP报错:未找到指定的命名空间类 Aug 18, 2023 pm 11:28 PM

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

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

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

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

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

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扩展开发:如何使用命名空间组织和管理自定义函数? Jun 04, 2024 pm 12:59 PM

使用命名空间管理自定义函数至关重要,它允许开发者创建自己的命名范围,防止名称冲突。步骤包括:创建命名空间(namespace)、使用use语句导入命名空间、调用命名空间函数。在实战案例中,MyMath扩展演示了如何使用命名空间组织数学函数,提高可读性和可维护性。

如何利用PHP7的命名空间和自动加载机制组织代码的结构? 如何利用PHP7的命名空间和自动加载机制组织代码的结构? Oct 20, 2023 am 08:57 AM

如何利用PHP7的命名空间和自动加载机制组织代码的结构?摘要:随着PHP7的推出,命名空间和自动加载机制成为了PHP开发中不可忽视的重要特性。本文将介绍如何利用PHP7的命名空间和自动加载机制来组织代码的结构,并通过具体的代码示例进行说明。一、什么是命名空间?命名空间是PHP7引入的一种机制,用于解决不同类库或代码文件之间可能出现的命名冲突问题。通过命名空间

PHP 5.3新功能:如何使用命名空间解决类名冲突问题 PHP 5.3新功能:如何使用命名空间解决类名冲突问题 Jul 30, 2023 pm 12:25 PM

PHP5.3新功能:如何使用命名空间解决类名冲突问题引言:在PHP的开发过程中,随着项目变得越来越庞大和复杂,类名冲突问题也随之而来。为了解决这个问题,PHP5.3版本引入了命名空间的概念。命名空间提供了一种将相关的类、函数和常量组织在一起的方式,以避免命名冲突的问题。本文将详细介绍PHP命名空间的概念和如何使用命名空间解决类名冲突问题,并附带代码示例

See all articles