이 글은 js의 모듈식 분석(네임스페이스)을 공유합니다. 필요한 참조 가치가 있는 친구들이 참고할 수 있습니다.
코드는 모듈화되어 다양한 시나리오에서 모듈을 재사용할 수 있도록 모듈로 구성됩니다.
모듈은 독립적인 js 파일입니다. 모듈 파일에는 클래스 정의, 관련 클래스 집합, 유틸리티 함수 라이브러리 또는 실행할 일부 코드가 포함될 수 있습니다. 모듈 형태로 코드를 작성하면 js 코드 세그먼트가 모듈로 간주될 수 있습니다.
모듈 목표는 프로그램 개발을 지원하고, 분산 소스에서 코드 어셈블리를 처리하고, 코드가 올바르게 실행되도록 하는 것입니다.
오염 방지 글로벌 변수는 객체를 네임스페이스로 사용하여 함수의 값과 네임스페이스 객체의 속성(즉, 전역 변수를 통해 참조)을 저장합니다.
var collections; // 先声明一个全局变量 if (!collections) // 如果它原先不存在 collections = {}; //创建一个新对顶层命名空间,加判断是因为防止出现覆盖 collections.sets = {}; // 将sets命名空间创建在其内部 // 下面开始定义相关的类 collections.sets.AbstractSet = function(){};
네임스페이스 세트 클래스에서 세트를 자주 사용하는 경우, set 클래스를 전역 네임스페이스로 가져옵니다.
var Set = sets.Set; // 将Set倒入到全局命名空间中 var s = new Set(); // 这样就不用加set前缀了
규칙, 모듈 파일과 네임스페이스가 일치해야 합니다.
예를 들어, com.davidflanagan.collections를 사용합니다. com/davidflanagan/collections/sets.js에 있습니다
위는 경로, 규칙입니다
모듈 외부에서 사용할 일부 API 내보내기 함수, 속성, 클래스 및 메서드를 포함한 다른 사람에 의해.
모듈을 구현하려면 일부 보조 함수와 메서드가 필요합니다.
함수와 메서드는 비공개 네임스페이스로 표시되지 않습니다.
함수 범위를 개인 네임스페이스, 즉 모듈 함수로 사용
/* * 模块函数中的Set类 * 时间:2018/07/22 13:15 */ // 声明全局变量Set, 使用一个函数返回值给其赋值 // 函数结束后紧跟着圆括号,立即执行 // 将其返回值赋值给Set // 这为函数表达式,没有创建函数变量 var Set = (function(){ function Set() { // 这个构造函数为局部变量 this.values = {}; // 这个对象用来保存这个集合 this.n = 0; // 集合中的个数 this.add.apply(this, arguments); // 将所有的参数添加到集合中 }; // 给Set.prototype定义实例方法 Set.prototype.contains = function(vale) { // 这里调用v2s return this.values.hasOwnProperty(v2s(value)); }; Set.prototype.size = function() {/*...*/} // 这里的为辅助函数和变量 // 这里的变量不属于公有的api,但是都隐藏在函数的作用域内 // 因此,不需要将其定义为Set属性,或使用下划线用来标识 function v2s(val) {/*...*/}; // 这个模块的共有api为Set()构造函数 // 我们需要把这个函数从私有命名空间导出,以便在外部可使用,通过返回构造函数的方式导出 // 它会变成构造函数所指的值 return Set; }()); // 定义函数后立即执行
관련 권장사항:
# 🎜🎜#JavaScript의 Object.defineProperty() 메소드 분석
JS의 클래스 확장 및 객체지향 기술 분석# 🎜 🎜#
위 내용은 js(네임스페이스)의 모듈식 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!