Javascript 面向对象(一)(共有方法,私有方法,特权方法)

 更新时间:2012年05月23日 17:23:57   作者:  
最近在网上盾一些JS面向对象的东西。把其他高手们总结的东西,加上自己的理解,总结一下
私有方法:私有方法本身是可以访问类内部的所有属性的,即私有属性和公有属性。但是私有方法是不可以在类的外部被调用。

私有方法写法:
复制代码 代码如下:

function myClass () {
var private_attribute = initial_value;
function private_method () { }
var private_method2 = function () { }
}

实例showpet()就是一个私有方法

复制代码 代码如下:

var pet=function(){  var temp=""  //私有变量只有在函数或者对象作用域范围内能访问
function showpet(){
  alert("123")
}
showpet();//私有方法可以在函数作用域范围内使用。
}
showpet();//会出错
pet.showpet()//还是不能这样调用

var Penguin=new pet() //实例化一个pet对象
Penguin.showpet()//不好意思这样子还是不能让你调用。


公有方法:

  1.公有方法是可以在类的外部被调用的,

  2.但是它不可以访问类的私有属性。

  3.公有方法必须在类的内部或者外部通过类的prototype属性添加。

公有方法写法:

复制代码 代码如下:

function myClass () {
this.public_attribute = initial_value;
this.prototype.public_method = function () { }
}
myClass.prototype.public_attribute2 = initial_value;
myClass.prototype.public_method2 = function () { }

实例:
复制代码 代码如下:

var pet=function(){
function showname(){//私有方法
  alert(this.name)
}
  this.show=function(){ //如果这里不理解,请注意这个方法下面就要介绍了。
  showname();
  }
}
pet.prototype.setname=function(str){
name=str;
}
var Penguin=new pet()
  Penguin.setname("Penguin");//添加实例的name值为Penguin
  Penguin.show(); //弹出Penguin
  Penguin.setname("wind");//添加实例的name值为wind
  Penguin.show(); //弹出wind


特权方法:

  1.特权方法是可以在类的外部被调用的,

  2.但是它可以访问类的私有属性,并且也是可以访问类的公有属性,可以勉强的认为它是一种特殊的公有方法。

  3.但是它与上面的公有方法的声明与定义方式不同。特权方法必须在类的内部声明定义。

特权方法写法:
复制代码 代码如下:

function myClass () {
this.privileged_method = function () { }
}

实例
复制代码 代码如下:

var pet=function(){
function showname(){//私有方法
alert(this.name)
}
this.show=function(){//通过使用this关键字定义一个特权方法。
showname(); //在特权方法中访问私有方法;
}
}
pet.prototype.setname=function(str){
name=str;
}
var Penguin=new pet();//实例化一个pet对象
Penguin.setname("Penguin");//调用公有方法修改
Penguin.show(); //调用特权方法访问私有方法,弹出name


下面是我自己的一些理解:通过对上面这些的学习,结合我自己看的书。对于公有,私有,特权的理解如下:
公有方法:就是所有通过该类实例化出来的对象,共同都拥有或者说都可以使用的方法。一般把共用的方法,都放在“原型对象“当中,如果放在构造函数中,会重复创建共同的方法。

私有方法:不能在外部调用。
特权方法:利用的闭包原理,即通过作用域链,让内部函数能够访问外部函数的变量对象(即该类的私有变量、私有方法)。(作用域链,闭包,变量对象;这三个在《Javascript高级程序中有讲解》)

相关文章

  • javascript 写类方式之七

    javascript 写类方式之七

    dojo最新是1.3.1了,记得07年时还是0.4。文档也渐渐多了起来,用dojo的也慢慢多了。dojo还发布了core版,压缩后只有27kb。
    2009-07-07
  • Javascript 面向对象(一)(共有方法,私有方法,特权方法)

    Javascript 面向对象(一)(共有方法,私有方法,特权方法)

    最近在网上盾一些JS面向对象的东西。把其他高手们总结的东西,加上自己的理解,总结一下
    2012-05-05
  • CLASS_CONFUSION JS混淆 全源码

    CLASS_CONFUSION JS混淆 全源码

    这里通过JS字符串替换、随机数运算实现混淆JS代码,达到降低代码可读性,以保护代码的目的,需要的朋友可以参考一下
    2007-12-12
  • javascript 写类方式之五

    javascript 写类方式之五

    用 构造函数+原型 定义一个类;同一构造函数可以定义出多个类型
    2009-07-07
  • JS 继承实例分析

    JS 继承实例分析

    主要有三种方法: 1. this.method=Parent; this.method=Parent's constructor 2. Parent.call(this,arg,arg,arg.....);3.Parent.apply(this,arg.arg...) //for Array 还是来点实际的吧...
    2008-11-11
  • js对象的构造和继承实现代码

    js对象的构造和继承实现代码

    js对象的构造和继承实现代码,学习javascript面向对象的朋友可以参考下。写出跟漂亮与复用的代码。
    2010-12-12
  • javascript Base类 包含基本的方法

    javascript Base类 包含基本的方法

    一个Base类,包含基本的方法,大家可以在这个基础上拓展下功能。
    2009-07-07
  • JavaScript 工具库 Cloudgamer JavaScript Library v0.1 发布

    JavaScript 工具库 Cloudgamer JavaScript Library v0.1 发布

    研究了一年多的js,也差不多写一个自己的js库了。 我写这个不算框架,只是一个小型的js工具库,所以我用的名字是Library。
    2009-10-10
  • JavaScript 原型与继承说明

    JavaScript 原型与继承说明

    在上一遍我们简单的介绍了怎么样使用JavaScript进行构造函数的书写,现在来认识下JavaScript的构造函数其原理,主要是关注与原型的概念,首先看如下代码。
    2010-06-06
  • JavaScript 继承详解(三)

    JavaScript 继承详解(三)

    在第一章中,我们使用构造函数和原型的方式在JavaScript的世界中实现了类和继承, 但是存在很多问题。这一章我们将会逐一分析这些问题,并给出解决方案。
    2009-07-07

最新评论