• 原型模式&原型链


    1.每一个函数数据类型(函数,所有的类)天生都有一个prototype(原型)属性,里面存储的是公有的属性和方法,而且这个属性是一个对象数据类型的,浏览器就会给他开辟一个堆内存,开辟的这个堆内存中也有一个天生自带的属性叫constructor,而且指向的是这个类的本身.
    2.所有的对象数据类型(除了函数和基本数据类型,其他的都是,实例,prototype是对象数据类型)天生自带一属性个叫_ _ protot _ _,指向所属类型的原型.
    3.所有的类都是函数数据类型的,Object是一个类,说明Object是函数数据类型的.他就是函数Function类的一个实例

    [注意!]实例都是对象,prototype也是个对象Object是基类,他的原型上面没有_ _proto_ _
    
    实例通过this得到的是私有属性和方法,还可以继承所属类的公有属性和方法,比如说,每个数组都可以用sort这个方法,这个方法是在类Array原型上,因为所有的数组都是这个Array类一个具体的实例,所以只要是数组就可以用,实例可以得到公有类的方法
    
    Array.prototype.removeRepeat=function(){
    //this 就是那个具体的数组实例
    for(var i=0;i<this.length;i++){
    if(this.indexOf(this[i])!==this.lastIndexOf(this[i])){
    this.spalice(i,1);
    i--;
    }
    }return this
    }
    var ary=[1,2,3,1,3,4,53,3,2,1];
    cosole.log(ary.removeRepeat().sort().splice(0,1,"a"));
    
    

    =小练习============
    思考作业,模拟数组slice方法,在数组原形上增加方法

    ======================================


    面试题
    1.用面向对象的思想扩展方法-->基于内置类的原型扩展方法.
    2.链式写法实现的原理 (return this)
    3.谈谈你对原型的理解

    ==================================

    原型链

    实例.属性名,遇到属性名先看是不是自己的私有属性,如果是的话就用私有的,不是的话,通过实例的_ _ proto _ _ 找到所属的原型(prototype)还没有的话,通过所属类的prototype的 _ _proto _ _继续找,一直找到基类Object的prototype

    ===

    Object.prototype.x = 10;
        Object.prototype.y = 20;
        Object.prototype.sum = function() {
            console.log(this.x + this.y)
        };
        function Fn() {
            this.x = 100;
            this.y = 200;
            this.sum = function() {
                console.log(this.x + this.y)
            }
        }
        Fn.prototype.sum = function() {
            console.log(this.x + this.y);
        }
        Fn.prototype.x = 1;cou
        Fn.prototype.y = 2;
        var f1 = new Fn;
        var f2 = new Fn;
    
        Fn.prototype.sum();
        f1.__proto__.__proto__.sum();
    
        Fn.prototype.__proto__.sum();
        
        f1.__proto__.sum==f2.__proto__.__proto__.sum
    
        f1.__proto__.sum==Fn.prototype.sum
    
        f1.__proto__.sum==Fn.prototype.__proto__.sum
    
        f1.__proto__.__proto__.sum==Fn.prototype.__proto__.sum
    
        Object.prototype.sum==Object.prototype.sum
    

    =有趣的东西==

    //caller:检验函数被谁调用过
        function Fn() {
            console.log(arguments.callee.caller);
            console.log(Fn.prototype.constructor === arguments.callee);
        }
        function fn() {
            Fn()
        }
        fn();
    
    
        function sum(n) {
            console.log(arguments.callee===arguments.callee.caller);
            if(n<=0){
                return 0
            }
            return n+sum(--n);
        }
        console.log(sum(10));
    </script>
    
  • 相关阅读:
    时间管理(二):时间管理的六项基本原则
    时间管理(一): 达成目标需重视时间管理
    oracle 工作机制 如何工作的
    如何快速彻底删除 svn checkout出来的文件夹
    win7 安装oracle11g注意事项
    eclipse findbugs does not match outer scope rule: MutexSchedulingRule encounter a pro
    oracle ora12154 无法解析连接字符串
    oracle 动态执行表不可访问 异常处理
    log4j配置
    linux 永久 修改 主机名 ip
  • 原文地址:https://www.cnblogs.com/Jiazexin/p/7080347.html
Copyright © 2020-2023  润新知