如何解决js面向对象开发中的命名空间冲突
背景
- 目的是开发一套图表库,供外部使用
- 使用js自定义“类”,并有继承关系
- 在使用这些自定义“类”的时候,有命名冲突的问题
- 使用该图表库的时候,无法保证库中的变量不和外部产生命名冲突
问题描述
如下图所示,
- dog,cat拥有相同“类包”(class packge)结构
- dog,cat拥有同名的“类文件”(MyClass.js , ExtendsMyClass.js)
---当然它们的内容不同 - 要在index.html中同时使用dog,cat各个类的实例
- 问题1来了: 命名冲突
- 问题2来了: 无法避免index.html中其他js脚本和图表库产生命名冲突
想到的可能的解决方案
<一>
将所有类的名字特异唯一化。
比如:
doc --- action --- MyClass.js / ExtendsMyClass.js
cat --- action --- MyClass1.js / ExtendsMyClass1.js
pig --- ...
mouse --- ...
...
这是“超级XX”的方法,不予理会!
<二>
模块化,不是有AMD,CMD嘛?
抱歉,没接触过。
收集资料,看了,没有理解透。
能否解决我的问题,需要朋友们指点。
<三>
把dog结构下所有“类”文件的内容都定义在一个文件中,且用
var moduleDog = new Object{ ... dog的全部内容 ... }
包裹起来。
cat也是如此。
这种“模块化”在有“类继承”的本例中是否可行?需要朋友们指点。
<四>
其他方案未知,需要朋友们指点。
代码
cat的 MyClass.js
function MyAction()
{
this.name = 'cat' ;
}
cat的 ExtendsMyClass.js
function ExtendsMyAction()
{
this.name = 'extends cat' ;
}
ExtendsMyAction.prototype = new MyAction() ;
ExtendsMyAction.prototype.constructor = ExtendsMyAction ;
dog的 MyClass.js
function MyAction()
{
this.name = 'dog' ;
}
dog的 ExtendsMyClass.js
function ExtendsMyAction()
{
this.name = 'extends dog' ;
}
ExtendsMyAction.prototype = new MyAction() ;
ExtendsMyAction.prototype.constructor = ExtendsMyAction ;
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(5)
TypeScript
ES6
的超集,支持async
、Promise
、yield
等新语法适合面向对象的场景
最终会编译成
es5
的js
代码,也就是任何浏览器可以执行的JS
使用编辑器
Visual Studio Code
无缝编辑,编译也只要运行tsc
即可输出目标js文件比如
下面例子中:
namespace
命名空间abstract
虚类、虚函数extends
继承: number
参数类型: boolean
返回类型x: number = 0
默认参数值public x
类变量以及作用域public position
类作用域constructor
构造函数public get
getter setter/ui/base.ts
/ui/sharp.ts
/ui/sharp/rect.ts
调用
调用方式 无特殊,
js
即可Symbol 可以吗
requirejs或直接上es6使用webpack打包
首先你这个例子不应该出现类名重复的情况.为什么不在构造函数中传入参数来实例化.
记住在编写代码之前,先保证设计的合理性!不要试图解决错误的逻辑.
还有现在是 es6 的时代,请自行学习 es6 的语法.来定义类.推荐 阮一峰 es6 入门
此外前端以进化到编译型.请学习 webpack 来打包代码.自行参看官方文档.
所以我的建议是.
决定采用“伪命名空间”的方式解决本问题。
理由:
===========================================
“伪命名空间示例”
var myNamespace =
{
}
===========================================
个人理解(未必正确)
无论TS或ES6,都是通过语法糖的形式为原生jS做了一层包装,最终都要转译为JS原生代码。
那么,掌握原生JS解决下面问题的方法,是深入JS所必须的:
今后需学习的地方:
没有TS或ES6开发的经验,不好做判断。但是,仅仅通过TS和ES6中对“类”,“类继承”,“模块化”的浅显了解,个人感觉这些语法糖使得原本简单的JS代码变得复杂起来,这也是是代价。
希望有实战经验的朋友们对TS或ES6在解决本问题上做“能”或“不能”的判断,如果能够提供简单示例代码,那将非常感谢。
此问题暂时不关闭,等待有实战经验的朋友们给予指点!