原型链注意点-P16-2019-12-06

<script>
        function Student(name, age, sex) {
            // 一般情况下对象的属性在构造函数中设置
            this.name = name;
            this.age = age;
            this.sex = sex;
        }
        // 一般方法在构造函数的原型上设置prototype
        Student.prototype.writeIt = function() {
                document.write('Hello PROTOTYPE!')
                    // alert("Hello PROTOTYPE")
            }
            // 多个方法可以用以下形式写但是要注意
        console.dir(Student.prototype);
        //注意以上代码★★
        Student.prototype = {
            writeIt: function() {
                document.write('Hello PROTOTYPE!')
                    // alert("Hello PROTOTYPE")
            },
            eat: function() {
                log("....")
            }
        }
        //注意以下代码★★
        console.dir(Student.prototype);

        var a = new Student();
        // a.writeIt();
        // console.log(a.constructor);
    </script>
第二种写法.png

所引起的问题.png

当我们访问constructor属性时先找本身有没有,再找原型对象中有没有,结果原型对象也没有,就在找原型对象的原型对象结果找到了时object类型

image.png

怎么解决呢?

解决办法.png
image.png
//代码如下
 Student.prototype = {
            constructor: Student,
//再次指定该对象到底属于哪类对象
            writeIt: function() {
                document.write('Hello PROTOTYPE!')
                    // alert("Hello PROTOTYPE")
            },
            eat: function() {
                log("....")
            }
        }
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容