博客列表 >作用域和闭包; 类与类的继承

作用域和闭包; 类与类的继承

杰西卡妈妈
杰西卡妈妈原创
2021年04月13日 20:09:34647浏览

1. 作用域

1). 全局作用域,默认的,不可删除,如果在是浏览器中运行js,那么全局对象就是window
let site = “google”;
console.log(site);
console.log(window.site);

2). 函数作用域, 仅限在当前作用域内访问, 外部不可见,否则会报错。

  • 作用域链, 自身查找,如果没有就返回上一级
    function getSite() {
    let domain = google.com
    return `${site} [${domain}];
    console.log(getSite());

3). 块作用域,包在大括号里的语句就是块
{var a = 1;
var B = 2;}
console.log(a, B);

2. 闭包

  • 所有函数都是闭包
  • 能够访问自由变量的函数
  • 在函数A内部有个函数B,函数B可以访问函数A中的变量,函数B就是闭包
  • 通过闭包来访问内部的私有变量
    function sum(a, b) {
    return a + b + c;
    }
    console.log(sum(4, 5));

function Hello() {
let email = “abc@abc.com”;
return function d(){
return email;
},
};
console.log(Hello());

2. 类与类的继承

  • 类和构造器constructor
    constructor是类的构造函数 用与传递参数 返回实例对象,通过new生成实例时自动调用该方法.

    <script>
    function User(name, email) {
    this.name = name;
    this.email = email;
    this.show = function () {
    return { name: this.name, email: this.email };
    };
    }
    const user = new User(“Peter”, “abc@abc.com”);
    console.log(user);
    </script>

  • 类是一个模板
  • 原型共享方法,通过对象来调用

    <script>
    class User1 {
    constructor(name, email) {
    this.name = name;
    this.email = email;
    }
    show() {
    return { name: this.name, email: this.email };
    }
    }
    const user1 = new User1(“Bill”, “ab@ab.com”);
    console.log(user1);
    console.log(user1.show());
    </script>

  • 继承,是对父类进行一些扩展,添加一些新的属性或方法
    class Child extends User1 constructor(name, email, gender) {
    super(name, email);

    1. this.gender = gender;
    2. }
    3. show() {
    4. return { name: this.name, email: this.email, gender: this.gender };
    5. }
    6. }
    7. const child = new Child("Bob", "oy@qq.com", "male");
    8. console.log(child.show());
声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议