js 实现继承

Posted 白与小寒

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js 实现继承相关的知识,希望对你有一定的参考价值。

我们现在要做的一件事情是像其他语言的面向对象一下实现继承多态

具体要求如下:

一个 Father 构造函数,一个 Child 构造函数,其中改写 Father中的部分参数, new Child() 表示出一个新的child

        var Father = function (name) {
            this.name = name
            this.say = function () {
                console.log(i am  + name)
            }
        }

        var Child = function (name,age) {
            this.age = age;
            this.say = function () {
                console.log("name:" + this.name + " and age:" + this.age);
            }
        }  
        Child.prototype = new Father()
        var he = new Child(asd,12)
     console.log(he.firstName) // qiao
        console.log(he.name)  
        console.log(he.age)
        he.say()    

 无法输出 name 是因为不能穿参数

    var Father = function (name) {
            this.name = name
            this.firstName = qiao
            this.say = function () {
                console.log(i am  + name)
            }
        }
        var Child = function (name,age) {
            this.tempMethod = Father
            this.tempMethod(name)
            this.age = age;
            this.say = function () {
                console.log("name:" + this.name + " and age:" + this.age);
            }
        }  
        
        var he = new Child(asd,12)
        console.log(he.firstName)   // qiao
        console.log(he.name)    // sad
        console.log(he.age)     // 12
        he.say()                // name:undefined and age:12

 

这样书写就可以继承name了

 

利用call可以这样书写

    var Child = function (name,age) {
            Father.call(this,name)
            this.age = age
            this.say = function(){
                console.log(i am  + name +and age + age )
            }
        }  

 

利用apply的话会更加巧妙一点,不用管参数是什么

      var Child = function (name,age) {
            Father.apply(this,arguments)
            this.age = age
            this.say = function(){
                console.log(i am  + name +and age + age )
            }
        }  

 


以上是关于js 实现继承的主要内容,如果未能解决你的问题,请参考以下文章

java 代码片段

JS实现继承的几种方式

JavaScript笔试题(js高级代码片段)

JS如何实现继承?

js几种继承方式(六种)

js实现继承