【JS public、private、protected 不知道怎么区分?】

概念:

在前端开发中,public、private和protected是一些关键字,用于定义类中的属性和方法的访问权限。

  • public:public是默认的访问修饰符,表示属性或方法可以在类的内部和外部被访问。这意味着可以在类的实例化对象中直接访问该属性或方法,也可以通过类的实例化对象的引用访问。

  • private:private是私有的访问修饰符,表示属性或方法只能在类的内部被访问。这意味着不能在类的实例化对象中直接访问该属性或方法,也不能通过类的实例化对象的引用访问。私有属性和方法通常用于隐藏类的内部实现细节,只允许通过公共方法来访问。

  • protected:protected是受保护的访问修饰符,表示属性或方法可以在类的内部和子类的内部中被访问。这意味着可以在类的实例化对象中直接访问该属性或方法,也可以通过子类的实例化对象的引用访问。受保护的属性和方法通常用于定义类的内部状态,只允许类的子类访问。

public:

class Person {
  public name: string = 'xxx';
  public sayHello() {
    console.log('Hello', this.name);
  }
}

class Student extends Person {
  public introduce() {
    console.log('i am' + this.name);
  }
}

const per = new Person();

console.log(per.name); // xxx
console.log(per.sayHello()); // Hello xxx

const stu = new Student();
console.log(stu.name); // xxx
console.log(stu.sayHello()); // Hello xxx
console.log(stu.introduce()); // i am xxx

private:

class Person {
  private name: string = 'xxx';
  public sayHello() {
    console.log('Hello', this.name);
  }
}

class Student extends Person {
  public introduce() {
    console.log('i am' + this.name);
  }
}

const per = new Person();

console.log(per.name); // 外部不能访问private属性和方法
console.log(per.sayHello()); // 通过公共方法能访问private属性和方法

const stu = new Student();
console.log(stu.name); // 子类不能访问父类private属性和方法
console.log(stu.sayHello()); // Hello xxx
console.log(stu.introduce()); // 子类内外部都不能访问父类的private属性和方法

protected:


class Person {
  protected name: string = 'xxx';
  public sayHello() {
    console.log('Hello', this.name);
  }
}

class Student extends Person {
  public introduce() {
    console.log('i am' + this.name);
  }
}

const per = new Person();

console.log(per.name); // 外部不能访问protected属性和方法
console.log(per.sayHello()); // 通过公共方法能访问protected属性和方法

const stu = new Student();
console.log(stu.name); // 子类外部不能访问父类protected属性和方法
console.log(stu.sayHello()); // Hello xxx
console.log(stu.introduce()); // i am xxx  子类内部方法都访问父类的protected属性和方法
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这些是 JavaScript 中的关键字(keywords),它们有着特殊的含义。下面是它们的解释: - `arguments`:一个包含所有传递给函数的参数的类数组对象。 - `break`:跳出当前循环或 switch 语句。 - `case`:在 switch 语句中匹配一个值并执行相应的语句。 - `catch`:捕捉 try 语句中抛出的异常并执行相应的处理代码。 - `class`:声明一个类。 - `const`:声明一个只读的常量。 - `continue`:跳过当前循环中的剩余代码并继续下一次循环。 - `debugger`:在代码中设置一个断点,用于调试 JavaScript 代码。 - `default`:在 switch 语句中,如果没有任何 case 语句匹配,则执行 default 语句。 - `delete`:删除一个对象的属性或一个数组的元素。 - `do`:执行一个语句块并重复执行,直到 while 语句的条件为 false。 - `else`:在 if 语句中,如果条件为 false,则执行 else 语句块。 - `enum`:声明一个枚举类型。 - `eval`:将传入的字符串作为 JavaScript 代码执行。 - `export`:将一个模块中的变量、函数或类导出。 - `extends`:继承一个类。 - `false`:布尔类型的 false 值。 - `finally`:在 try 语句中,无论是否有异常抛出,都会执行 finally 语句块中的代码。 - `for`:执行一个循环,可以是 for 循环、for...in 循环或 for...of 循环。 - `function`:声明一个函数。 - `if`:执行一个条件语句块,如果条件为 true,则执行 if 语句块中的代码。 - `implements`:实现一个接口。 - `import`:导入一个模块中的变量、函数或类。 - `in`:检查一个属性是否存在于一个对象中。 - `instanceof`:检查一个对象是否是某个类的实例。 - `interface`:声明一个接口。 - `let`:声明一个块级作用域的变量。 - `new`:创建一个对象实例。 - `null`:表示一个空值。 - `package`:声明一个包。 - `private`:声明一个私有的类成员。 - `protected`:声明一个受保护的类成员。 - `public`:声明一个公共的类成员。 - `return`:从一个函数中返回一个值。 - `static`:声明一个静态的类成员。 - `super`:调用一个父类的构造函数或方法。 - `switch`:在多个 case 语句中执行一个分支。 - `this`:引用当前对象。 - `throw`:抛出一个异常。 - `true`:布尔类型的 true 值。 - `try`:执行一段可能抛出异常的代码,并将异常抛出给相应的 catch 语句进行处理。 - `typeof`:返回一个值的类型。 - `var`:声明一个变量,可以是全局变量或函数作用域的变量。 - `void`:指定一个函数没有返回值。 - `while`:重复执行一个语句块,直到条件为 false。 - `with`:将一个对象的属性添加到当前作用域中,使其可以直接访问。 - `yield`:暂停一个生成器函数并返回一个值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值