[code]function Container(param) {
this.member = param;
}[/code]
构造一个新的对象:
[code]var myContainer = new Container('abc');[/code]
然后,公有变量 myContainer.member 就拥有了值 'abc'。
[code]Container.prototype.stamp = function (string) {
return this.member + string;
}[/code]
然后我们就可以调用这个方法:
[code]myContainer.stamp('def')[/code]
返回'abcdef'。
[h3]私有[/h3]
私有(Private)成员是由构造器创建的。通常构造器中用var声明的变量和函数参数成为私有成员。
[code]function Container(param) {
this.member = param;
var secret = 3;
var self = this;
}[/code]
这个构造器创建了三个私有的实例变量:param,secret和self。
[code]function Container(param) {
function dec() {
if (secret > 0) {
secret -= 1;
return true;
} else {
return false;
}
}
this.member = param;
var secret = 3;
var self = this;
}[/code]
私有方法dec会检查实例变量secret,如果它大于0,自减1并返回true;如果它小于0,返回false。这样就实现了由这个架造器所创建对象的dec函数只能用三次的功能。
按惯例,我们创建了一个私有变量self。私有方法可以通过它来访问到对象本身。但这只是一种权宜之计,因为《ECMAScript Language Specification》中有一个错误,使得内部函数的this变量被设置成一个错误值。
公有方法(SharkUI.com注:即上文说的通过prototype创建的方法)是无法调用私有方法的,所以为了能使用私有方法,我们需要引入特权方法(privileged method)。
[h3]特权[/h3]
一个特权方法可以访问私有变量和方法,而它本身可以被公有方法和外界访问。你可以删除或替换一个特权方法,但不能修改它,也不能强制它放弃自己的密秘(SharkUI.com注:原文如此,可能是指它的特权,关于这点请高手指教)。
特权方法是在构造器内部通过this来创建的。
[code]function Container(param) {
function dec() {
if (secret > 0) {
secret -= 1;
return true;
} else {
return false;
}
}
this.member = param;
var secret = 3;
var self = this;
this.service = function () {
if (dec()) {
return self.member;
} else {
return null;
}
};
}[/code]
service是一个特权方法。前三次调用myContainer.service()将返回'abc',之后将返回null。service通过调用私有方法dec来访问私有变量secret。对于其他对象和方法来说,可以访问到service,但不能直接访问到私有的成员。
[h3]闭包[/h3]
这种公有、私有和特权成员模式的存在是由于JavaScript的内在机制:闭包。这意味着一个内部函数永远可以访问它外部函数的变量和参数,即使外部函数已经返回。这是JavaScript语言非常强大的一个特性。目前还没有关于JavaScript编程的书籍展示了如何来利用它,它们甚至都没有提到这一点。
私有和特权成员只能在对象初始化的时候创建,而公有成员可以被随时添加进来。
[h3]模式[/h3]
[code]function Constructor(...) {
this.membername = value;
}
Constructor.prototype.membername = value;[/code]
[code]function Constructor(...) {
var self = this;
var membername = value;
function membername(...) {...}
}[/code]
注:这句代码:
[code]function membername(...) {...}[/code]
事实上是以下代码的简略写法
[code]var membername = function membername(...) {...};[/code]
[code]function Constructor(...) {
this.membername = function (...) {...};
}[/code]
[h3]后记[/h3]
Douglas Crockford的这篇文章为我们写出更优美的JavaSciprt程序奠定了基础,为我们创建出更合理的面向对象应用和框架带来了可能。在这篇译文快要完成的时候,惊诧的发现作者网站上出现了一个本文中文版的链接。好事!有越来越多的中国人开始关注这些“边边角角”的技术。虽然做了重复工作,但一样希望各位能从这篇文章中有所收益。也希望有更多的人能投入到原创和翻译前端技术文章中来,在多数人浮躁的时候,我们需要更多基础性的工作。一周一篇不多,一年一篇不少,只要开始了就行!
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有