zoukankan      html  css  js  c++  java
  • 原型

    构造函数

    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源码分析教程

  • 相关阅读:
    python3爬虫-爬取新浪新闻首页所有新闻标题
    Python第三方库官网
    网页图片尺寸查看方法
    jquery插件开发常用总结一
    谷歌浏览器的input自动填充出现黄色背景解决方案(在已经输入内容之后)
    在背景图上面加滤镜层之后添加内容
    你是第几位访客简单实现--大学城项目首页
    html5总结
    win10怎么修改svn的用户和密码
    properties中的编码如何生成:例如u7AD9u70B9这种
  • 原文地址:https://www.cnblogs.com/PeriHe/p/8111096.html
Copyright © 2011-2022 走看看