• js14--原型2


    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
    <html>
        <head>
            <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
            <title>Untitled Document</title>
            <script type=text/javascript charset=utf-8>
            // isPrototypeOf(new instance); 判断原型的方法
            // ECMA5: Object.getPrototypeOf():根据实例对象获得原型对象
            function Person(){}
            Person.prototype.name = 'z3'; 
            Person.prototype.age  = 20 ; 
            Person.prototype.sayName  = function(){alert('我是原型对象的方法!')}; 
            var p1 = new Person();
            alert(p1.name); // z3 
            var prototypeObj = Object.getPrototypeOf(p1);
            alert(prototypeObj == Person.prototype);//true
            
            /* 每次代码读取一个对象的属性的时候: 首先会进行一次搜索:搜索实例对象里name的属性,看看有没有
             * 如果没有,再去p2的实例所对应的原型对象里去搜索name属性 如果有就返回 没有返回undefined
             */
            var p2 = new Person();
            p2.name = 'w5';        // 实例对象的name
            alert(p2.name);//w5
            delete p2.name ; //delete也可以删除方法
            alert(p2.name);        // 就想获得原型对象的name属性
            
            // 判断一个对象属性 是属于原型属性 还是属于实例属性
            var p3 = new Person();
            p3.name = 'z6';
            alert(p3.name);
            alert(p3.hasOwnProperty('name'));
            
            //in 操作符  : for-in 
            // in 操作符 判断属性是否是实例对象或者原型对象中
            var p1 = new Person();
            alert('name' in p1); // true
            var p2 = new Person();
            p2.name = 'w3';
            alert('name' in p2); // true
            // 就是判断一个属性 是否存在原型中
            // 在原型对象中 是否存在这个属性 第一个参数:当前对象 ,第二个参数:要判断的属性
            function hasPrototypeProperty(object , name){
                return !object.hasOwnProperty(name) && name in object ;
            }
            
            var p3 = new Person();
            p3.name = 'xiao A';
            alert(hasPrototypeProperty(p3,'name'));
            
            
            // ECMA5新特性 Object.keys();
            // 拿到当前对象里的所有keys 返回一个数组
            var p1 = new Person();
            p1.name = 'z3';
            p1.age = 20 ; 
            var attributes = Object.keys(p1);
            alert(attributes);
            var attributes2 = Object.keys(Person.prototype);
            alert(attributes2);
            
            
            // ECMA5 constructor属性: 该属性是不能被枚举的[eable = false]
            // Object.getOwnPropertyNames 枚举对象所有的属性 :不管该内部属性能否被枚举
            var attributes3 = Object.getOwnPropertyNames(Person.prototype);
            alert(attributes3);
            </script>
        </head>
        <body>
        </body>
    </html>
  • 相关阅读:
    并查集(Java实现)
    Flask入门HelloWorld
    归并排序及优化(Java实现)
    用IDEA生成javadoc文档
    windows下安装Virtualenvwrapper
    模板方法模式Template Method(Java实现)
    部署Flask项目到腾讯云服务器CentOS7
    冒泡排序及优化(Java实现)
    迭代器模式Iterator(Java实现)
    堆排序(Java数组实现)
  • 原文地址:https://www.cnblogs.com/yaowen/p/6865934.html
Copyright © 2020-2023  润新知