• 技术文章 >web前端 >js教程

    JS子类如何实现用Object.getPrototypeOf去调用父类

    零到壹度零到壹度2018-03-22 11:46:09原创1153
    这次给大家带来JS子类如何实现用Object.getPrototypeOf去调用父类,下面就是实战案例,一起跟随小编的脚步来看一下。

    每个function有个prototype属性,称为原型。每个对象也有个原型,Firefox/Safari/Chrome/Opera 中可以通过__proto__来访问,IE6/7/8中没有提供相关接口。

    function Person(){
    this.method1 = function(){}
    }
    Person.prototype.method2 = function(){}
    function Man(){}
    Man.prototype = new Person();
    Man.prototype.m1 = function(){}
    Man.prototype.m2 = function(){}
    var m = new Man();
    for(var a in m.__proto__){
    alert(a);
    }

    定义了父类Person,子类Man。new一个Man的对象,打印出所有属性。

    ECMAScript V5为Object添加了静态的getPrototypeOf方法( Firefox/Chrome已实现 ),用来获取对象的原型。用它可以模仿Java的super。

    function Person(){
    this.method1 = function(){alert(1)}
    }
    Person.prototype.method2 = function(){alert(2);}
    function Man(){
    this.m1 = function(){
    Object.getPrototypeOf(this).method1();
    }
    }
    Man.prototype = new Person();//原型继承
    Man.prototype.m2 = function(){
    Object.getPrototypeOf(this).method2();
    }
    var man = new Man();
    man.m1();
    man.m2();


    子类Man中挂在this上的m1方法中调用父类Person中挂在this上的method1,挂在prototype上的m2方法调用父类prototype上的method2。

    以上可以看出对象原型不但包括其构造器prototype上的属性,也包括构造器中this上的属性。当然由于JavaScript中上下文的原因,父类中的this不能在子类中不能很好的自动转换,需要一些技巧完成。

    Java中是这样的

    package bao1;
    class Person {
        private String name;
        Person(String name) {
          this.name = name;
      }
      public void method1() {
          System.out.println(this.name);
        }
      }
          class Man extends Person{
            Man(String name) {
              super(name);
        }
        public void m1() {
           super.method1();
          }
        }
         public class Test 
         {public static void main(String[] args) {
         Man man1 = new Man("Jack");man1.m1();
        }
      }

    以上就是JS子类如何实现用Object.getPrototypeOf去调用父类的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    自己动手写 PHP MVC 框架:点击学习

    快速了解MVC架构、了解框架底层运行原理

    上一篇:浅析JavaScript中__proto__与prototype的关系 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• 浅析Angular中的Change Detection机制• 浅析Angular变更检测中的订阅异步事件• 一文聊聊node中的path模块• Angular学习之聊聊Http ( 错误处理 / 请求拦截 )• 一文详解多版本node的安装和管理
    1/1

    PHP中文网