虽说js是一门面向对象的语言,但是它并不像C++,C#,Java等那样,具有典型的面向对象的特征。因此在这里总结一下如何编写具有面向对象特征的程序。
【私有变量】 在对象内部使用'var'关键字来声明,而且它只能被私有函数和特权方法访问。
【私有方法】 在对象的构造函数里声明(或者是通过var functionName=function(){...}来定义)。
【特权方法】通过this.methodName=function(){...}来声明而且可能被对象外部的代码调用。
【公共属性】 通过this.variableName来定义而且在对象外部是可以读写的。不能被私有函数所调用。
【公共方法】 通过ClassName.prototype.methodName=function(){...}来定义可以从对象外部来调用。
【原型属性】 通过ClassName.prototype.propertyName=someValue 来定义。
【静态属性】 通过ClassName.propertyName=someValue 来定义。
【静态方法】 通过ClassName.funName=function(){...} 来定义。
function MyFunc(){ //私有属性/方法 var privateVar = "私有属性"; var privateMethod = function () { alert(privateVar); }; //公有属性/特权方法 this.publicVar = "公有属性"; this.particularMethod = function () { privateMethod(); }; //静态属性/方法无需实例化,只能通过对象本身调用 MyFunc.staticVar = "静态属性"; MyFunc.staticMethod = function () { alert(MyFunc.staticVar); } } //公有(原型)方法 必须先实例化对象 MyFunc.prototype.publicMethod = function () { alert(this.publicVar); }; //原型属性 MyFunc.prototype.prototypeVar = "原型属性";
其中特权方法和公有方法有区别又有共同点:
相同点:
1. 都可以在构造函数外部公开访问。
2. 都可以访问公有属性。
不同点:
1. 每个实例都要拥有一份特权方法的副本(除在单例中使用外,需要考虑内存),而公有方法为所有实例共享。
var m1 = new MyFunc(); var m2 = new MyFunc(); console.log(m1.particularMethod === m2.particularMethod)//false console.log(m1.publicMethod=== m2.publicMethod)//true
2. 特权方法可以访问私有属性和方法,而公有方法不能(不在函数内部),这个很好理解。