首页 > 编程语言 > 详细

JavaScript构造函数

时间:2021-02-15 23:38:53      阅读:34      评论:0      收藏:0      [点我收藏+]
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>
  
</body>
<script>
  // ES5构造函数:
  // function Person(name) {
  //   this.name = name; //公共属性
  //   this.age = 20;
  // }
  // Person.prototype.fn = function() {
  //   console.log("...");
  // } //公共方法

  // ES5静态属性:
  // Person.num = 10;

  // ES6类:
  class Person {
    static num = 10; //ES6静态属性
    #height = "173cm"; //ES2020私有属性
    constructor(name) {
      this.name = name; //公共属性
      this.age = 20;
    } //构造函数
    fn() {
      console.log("...");
    } //公共方法

    // 需要通过公共方法调取私有属性:
    getAge() {
      return this.#height;
    }
  }

  // 调取静态属性不需要实例化:
  console.log(Person.num);

  // 实例化:
  let zhangsan = new Person("张三");
  // 构造函数中的this指向实例化对象zhangsan
  // "张三"传入constructor中,赋值给了this.name

  // 调取属性:
  console.log(zhangsan.name);
  console.log(zhangsan.age);

  // 调取方法:
  zhangsan.fn();

  // 调取私有属性:
  console.log(zhangsan.getAge());

  // 运行结果:
  // 10
  // 张三
  // 20
  // ...
  // 173cm
</script>
</html>

 

JavaScript构造函数

原文:https://www.cnblogs.com/starlog/p/14403442.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!