JS高级-day06-构造函数 重点 难点

构造函数 - 重要 难点

  1. 提取函数到外部 实现了 多个实例共享一个函数 (优化内存空间)
  2. 弊端 会污染全部变量

构造函数

    <script>
        /*
        1. 构造函数 本质 其实也是一个函数
        2. 作用 用来创建对象
        3. 以前见过构造函数
            1 Set 构造函数
            2 Array 构造函数
            3 Object
            4 Strinf
            5 Number
            6 Boolean
            7 Date
        4. 只要他被 new  它 就是构造函数

        5. Person 构造函数 首字母是大写 (规范)
        6. per 被new 出来的对象 称之为  实例!!!  
        */
        function person (){}

        // person 就是一个构造函数 被new
        const per = new person()
        console.log(per);
    </script>

构造函数和this

    <script>
        //  每一个构造函数中 都存在 有一个 魔鬼  this
        // 构造函数 默认情况下 就是返回了 this
        // this 等于你所new出来的实例  per
  
        // 只要给构造函数中的this 添加 属性或者方法
        // 那么 实例 自然拥有对应的属性和方法
  
        function Person() {
          this.username = '悟空'; // per也增加了一个属性
          this.add=()=>{};
          this.clear=()=>{};
        }
  
        const per = new Person();
        per.username = '悟空';
  
        const per2 = new Person();
  
        console.log(per);
        console.log(per2);
  
      </script>

构造函数 - 弊端

    <script>
        function Person() {
          this.say = function () {};
        }
        const p1 = new Person();
        const p2 = new Person();
        console.log(p1 === p2); // 两个对象的比较 内存地址 false
        console.log(p1.say === p2.say);// false 两个函数 存放在不同地址中
  
        // const s1 = new Set();
        // const s2 = new Set();
        // console.log(s1 === s2);// false
        // console.log(s1.add === s2.add); // true 
  
        // s1 和 s2 共享一个方法   
        // p1 和 p2 没有共享一个 
  
      </script>

对象在堆中情况

    <script>
        const obj1 = { username: '八戒' };
        const obj2 = { username: '八戒' };
  
        // console.log(obj1===obj2);// false 内存中的地址
  
        const obj3 = obj2;
        // console.log(obj3 === obj2); //  true
  
        obj3.username="悟空";
        console.log(obj2);
      </script>

构造函数-方法指向同一个

    <script>
        function say() {
          console.log('外部单独的say方法');
        }
        function Person() {
          this.say = say;
        }
  
        const p1 = new Person();
        const p2 = new Person();
        console.log(p1 === p2); // false 
        console.log(p1.say === p2.say);// true
        /* 
        
        1 值类型 是存在 栈空间 适合存放 固定大小的数据
        2 引用类型(对象、数组、函数) 存在 堆空间  适合存放大小不固定的数据
        3 new了两个对象的时候, 两个对象的内存地址 不相等 
        4 我们希望 两个对象的方法 内存地址是相等!!! 
          1 在构造函数中 当我们定义方法的时候  一般都不会只在在 构造函数中写死 
            让我们方法 都指向外部 单独声明的方法  多个实例去共享方法!!! 

        */
        const obj1={username:"悟空"};
        const obj2={username:"悟空"};
        const obj3=obj2;
        obj3.username="八戒";
        console.log(obj2);
  
      </script>

构造函数的基本使用

    <script>
        // 构造函数的方式 创建一个对象
  
        // 姓名 属性
        // 说出自己的姓名 方法
  
        function say() {
          console.log('这个是Person的一个方法', this.name);
        }
        function fly() {
          console.log(this.name, '要起飞');
        }
  
        function Person(name, height) {
          this.name = name;
          this.height = height;
          this.say = say;
          this.fly = fly;
        }
        const p1 = new Person('八戒', 150);
        // p1.say();
        p1.fly();
  
        /* 
        1 构造函数的时候 属性 分成了两种 
          1 函数类型的属性 
            一般都是写在外部!!!
          2 非函数类型的属性 
            一般是写在内部!!! 
        
         */
      </script>

构造函数的使用演示

<body>
    <button>减少一根</button>
    <script>
      /* 
      1 有一个构造函数  Person
      2 有数字类型的属性 发量 hair =100
      3 有行为  decrease 减少   方法 
        发量 - 1 

      4 按钮 每点击一次 发量减少一根
       */

    //   1. 
    //   function decrease() {
    //     this.hair--;
    //   }
    
    //   2. 原型 prototype
      Person.prototype.decrease = function() {
        this.hair--;
      }

      function Person() {
        this.hair = 100;
        // this.decrease = decrease;
      }

      const btn = document.querySelector('button');

      const p1 = new Person();
      btn.addEventListener('click', function () {
        // 每点击一次按钮 new一个对象
        p1.decrease();
        console.log(p1.hair);
      });
    </script>
</body>
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容