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:实例化对象上的属性和来自原型继承的,不过不能访问类自身的属性和方法

猜你喜欢

转载自blog.csdn.net/crq131290x/article/details/83583197