zoukankan      html  css  js  c++  java
  • isPrototypeOf&&getPrototypeOf

    isPrototypeOf&&getPrototypeOf:https://www.cnblogs.com/giggle/p/5208199.html 

    在JavaScript这个一切皆为对象的世界里,难免会判断原型链的问题。那么我们就有必要了解了解isPrototypeOf和getPrototypeOf这两个方法咯。

    1、isPrototypeOf

    isPrototypeOf

    作用

    我的理解:确定一个对象的原型链中是否继承了prototype

    官方语言:Determines whether an object exists in another object's prototype chain.

    用法

    prototype.isPrototypeOf(object)

    备注

    如果object的原型链中有prototype,则返回true;否则,返回false

    我们一起demo下,看看isPrototypeOf到底是个什么东东。

    复制代码
    <!DOCTYPE html> 
        <head>
            <title>isPrototypeOf</title>
            <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
        </head>
        <body>
            <script>
                function A(){
                
                }
                var a = new A();
                //通过A创建一个对象a,所以a的__proto__是指向A.prototype的
                console.log(A.prototype.isPrototypeOf(a));
                //A.__proto__是指向Object.prototype的
                console.log(Object.prototype.isPrototypeOf(A));
                //由于A.prototype的__proto__是指向Object.prototype的,所以a也就含有Object.prototype咯
                console.log(Object.prototype.isPrototypeOf(a));
                
            </script>
        </body>
    </html>
    复制代码

    运行上面的代码,截图chrome,如下

    从上面的代码和chrome结果,可知isPrototypeOf的确是判断对象中的原型链是否继承了prototype。

    2、getPrototypeOf

    getPrototypeOf

    作用

    返回对象__proto__指向的原型prototype

    用法

    Object的静态方法,使用如下Object.getPrototypeOf(object)

    还是如此,我们一起demo下

    复制代码
    <!DOCTYPE html> 
        <head>
            <title>getPrototypeOf</title>
            <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
        </head>
        <body>
            <script>
                function Fn(){
                
                }
                var fn = new Fn();
                //通过getPrototypeOf静态方法,获得对象fn的prototype
                var proto = Object.getPrototypeOf(fn);
                //将获得的prototype添加一个name属性,并赋值
                proto.name = 'Monkey';
                //输出对象fn.name
                console.log(fn.name);
                //判断proto是否是Fn.prototype
                console.log( 'proto === Fn.prototype? ' + (proto === Fn.prototype) );
                //判断fn的__proto__是否指向了prototype
                console.log( proto.isPrototypeOf(fn));
            </script>
        </body>
    </html>
    复制代码

    执行上面的代码,截图chrome,如下

    从上面的代码和结果图,可得:

    getPrototypeOf,的确是返回对象__proto__指向的prototype。

  • 相关阅读:
    【BZOJ3028】食物(生成函数基础题)
    【BZOJ2438】[中山市选2011] 杀人游戏(Tarjan)
    【BZOJ4833】[Lydsy1704月赛] 最小公倍佩尔数(神仙数学题)
    【BZOJ2109】【BZOJ2535】[NOI2010] 航空管制(拓扑反向建图)
    【BZOJ2679】[USACO2012 Open] Balanced Cow Subsets(Meet in Middle)
    【BZOJ3091】城市旅行(再次重拾LCT)
    sass与compass实战
    【Sass初级】开始使用Sass和Compass
    nodejs、sass、backbone等api地址
    解读2015之前端篇:工业时代 野蛮发展(转)
  • 原文地址:https://www.cnblogs.com/bydzhangxiaowei/p/11524144.html
Copyright © 2011-2022 走看看