• 原型


    构造函数

    var a = {}; 其实是 var a = new Object(); 的语法糖

    var a = []; 其实是 var a = new Array(); 的语法糖

    function Foo(){...}; 其实是 var Foo = new Function(...); 的语法糖

    使用 instanceof 判断一个函数是否是一个变量的构造函数

    注意:构造函数名以大写字母开头更规范。

    五条原型规则

    1.所有的引用类型(数组,对象,函数),都具有对象特性,即可自由扩展属性(除了null)。

    2.所有的引用类型(数组,对象,函数),都有一个_proto_属性,属性值是一个普通的对象。

    _proto_:隐式原型。

    3.所有的函数,都有一个prototype属性,属性值也是一个普通对象。

    prototype:显式原型。

    4.所有的引用类型(数组,对象,函数),_proto_属性值 指向它的构造函数的“prototype”属性值。

    指向:完全等于。

    5.当试图得到一个对象的某个属性时,如果这个对象本身没有这个属性,那么会去它的_proto_(即它的构造函数prototype)中寻找。

    this指向,循环对象自身的属性。

    原型链

    instanceof

    用于判断引用类型属于哪个构造函数的方法。

    Q:如何准确判断一个变量是数组类型?

    A:使用instanceof Array ; typeof无法判断准确类型。

    Q:写一个原型链继承的例子。

    A:封装DOM查询。

    function Elem(id) {
        this.elem = document.getElementById(id);
    }
    Elem.prototype.html
    = function(val) { var elem = this.elem; if(val) { elem.innerHTML = val; return this; //链式操作 }else { return elem.innerHTML; } }
    Elem.prototype.on
    = function(type, fn) { var elem = this.elem; elem.addEventListener(type, fn); return this; } var div1 = new Elem('div1'); div1.html('<p>hello peri</p>').on('click', function() { alert('clicked'); }).html('<p>javascript</p>');

    Q:描述 new 一个对象的过程。

    A:创建一个新对象;this指向这个新对象;执行代码,即对this赋值;返回this。

    function Foo(name, age) {
        this.name = name;
        this.age = age;
        //return this; 默认有这一行
    }
    var f = new Foo('zhangsan', 20)

    Q:zepto(或其他框架)源码中如何使用原型链。

    A:自己读吧。

    Tips:读源码有技巧,先搜 相关源码解读分析 ,有技巧的去读。有源码阅读经历可以给简历加分,要说明阅读体会和收获,提升。zepto源码分析教程

  • 相关阅读:
    [非技术]简单预测中美关系未来的走向
    权限系统模型和常用权限框架
    [Tomcat]了解Tomcat,从它的结构开始
    [Mybatis]用AOP和mybatis来实现一下mysql读写分离
    [MQ]说一说MQ消息积压
    [MQ]再谈延时队列
    [Web] 浅谈Cookie,Session,Token
    k8s搭建
    微信公众平台开发(2)扫描二维码添加公众账号
    微信公众平台开发模式
  • 原文地址:https://www.cnblogs.com/PeriHe/p/8111096.html
Copyright © 2020-2023  润新知