面向对象的概念

// 原料
     function fn(){ //将这个函数中的this改变,指向new新创建的对象
         // 加工
         this.name = "root";
     }
    //     // 出厂
     var f = new fn();//创建了一个新对象
     var f2 = new fn();//创建了一个新对象
     console.log(f);//fn {name: "root"}

    console.log(f2)//fn {name: "root"}
     console.log(f == f2)//false

    // new的原理:
    //     1.创建了一个新的空对象
    //     2.将这个对象的__proto__和函数的prototype做连接
    //     3.将这个函数中的this改变,指向new新创建的对象
    //     4.检测函数有没有返回对象,没有返回对象,就返回new创建的对象

    // 工厂模式的模式是什么:
    //     设计模式之一:


    // 构造函数,构造自定义的函数,会在函数中使用this、找到被构造出来的对象
    // 隐患:一旦构造函数被直接执行,会错误的产生大量的全局变量
    // 解决隐患:解决不了
    // 自我约束:构造函数不要直接执行
    // 防止误操作:行业习惯:为了防止构造函数被直接执行,产生大量的全局变量,一般将需要被构造的函数的首字母大写,以此标志构造函数和正常函数的区别

     function Fn(){
         this.name = "root";
     }
     var f = new Fn()
     console.log(f.name)//root
    

     console.log(name)//空;

 

posted @ 2019-09-02 16:46  菜鸟小何  阅读(215)  评论(0编辑  收藏  举报