js面向对象系列二之private-protected-public

先看看private-protected-public是个神马玩意

public:public表明该数据成员、成员函数是对所有用户开放的,所有用户都可以直接进行调用
private:private表示私有,私有的意思就是除了class自己之外,任何人都不可以直接使用,私有财产神圣不可侵犯嘛,即便是子女,朋友,都不可以使用。
protected:protected对于子女、朋友来说,就是public的,可以自由使用,没有任何限制,而对于其他的外部class,protected就变成private。

诚然,在js当中也存在private-protected-public

js当中的private:es5当中,js只含有两种作用域,全局和函数,而且只要函数能够创造作用域,因为函数能创建作用域,所以就会有隔离效应,函数体内部的直接定义的属性和方法都是私有的

js当中的public :通过new关键词实例化时,this定义的属性和变量都会被复制一遍,所以通过this定义的属性和方法就是公有的。

通过prototype创建的属性在类的实例化之后类的实例化对象也是可以访问到的,所以也是公有的。

js当中的protected:这个地方指的是我们通过this定义一些方法去访问函数内部的private,这样在我们实例化对象时我们就能初始化对象的一些属性了

var Cat3 = function(age,name,weight){
    //private(函数内部定义,外部访问不到,实例化后的对象也访问不到)
    var num = 1;
    var age = age;
    function checknum(){
        console.log('private')
    }
    // protected(可以访问函数内部的私有属性和方法,实例化后就可以对实例化的类进行初始化拿到的函数)
    this.getName = function() {
        console.log(age)
    }

    this.getWeight = function() {
        console.log(weight)
    }

    // public(实例化后,实例化后的对象就能访问到)
    this.name = name;
    this.type = function() {
        console.log('Public')
    }
 }
// 原型上添加的方法实例化之后可以被实例化对象继承
Cat3.prototype.pro = function(){
    console.log('this is pro')
}
// .语法创建的属性和方法,只能通过该类访问,实例化对象访问不到
Cat3.sex = function() {
    console.log('sex')
}

var catp3 = new Cat3(5,"李栓但",'4kg')

console.log(catp3)

 

对于num就是Cat3类的private,外部都访问不到

对于getName就是Cat3类的protected,因为它能够访问Cat3类的private --age,所以可以采用此种方式来初始对象,即定义对象初始状态

对于name和type,实例化对象都会带有这个属性和方法,所以是public

 

简而言之:private:类自身拥有的属性和方法

protected:实例化对象通过这个方法能访问类自身拥有的属性和方法

public:实例化对象上的属性和来自原型继承的,不过不能访问类自身的属性和方法

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值