博客
关于我
js三大特性(附有HTML5代码实例)
阅读量:174 次
发布时间:2019-02-28

本文共 2598 字,大约阅读时间需要 8 分钟。

封装、继承以及多态是面向对象的共有特性,js作为面向对象的语言同样也支持这三个特性。

**封装:**当你需要隐藏一些属性和方法的时候,可以将这些属性和方法进行封装,然后通过外部接口(也就是公共的方法)进行调用。
举个例子:

    
Title

运行结果:

在这里插入图片描述
**继承:**类似于现实生活中的继承遗产。只可以继承父类拥有的东西。除此之外,js还支持多种继承。
讨论继承一般用动物作为例子,这是总的父类:

原型链继承: 将父类的实例作为子类的原型,使用prototype关键字进行继承

举个例子:

//原型继承    Cat.prototype = new Animal();    Cat.prototype.name = 'cat';    var cat = new Cat();    document.writeln(cat.name+"
"); cat.eat('fish'); cat.sleep(); document.writeln( (cat instanceof Animal) ); //true

运行结果:

在这里插入图片描述
优点:
父类新增原型方法/原型属性,子类都能访问到。且实例父类与子类共享
缺点:
来自原型对象的所有属性被所有实例共享且创建子类实例时,无法向父类构造函数传参
**实例继承:**为父类实例添加新特性,作为子类实例返回
举个例子:

function Cat(name){            var instance = new Animal();            instance.name = name || 'Tom';            return instance;        }        var cat = new Cat();        document.writeln(cat.name+"
"); cat.sleep(); document.writeln("Is Animal:"); document.writeln(cat instanceof Animal); // true document.writeln("
"); document.writeln("Is Cat:"); document.writeln(cat instanceof Cat); // false document.writeln("
");

运行结果:

在这里插入图片描述
优点:
返回的对象不受子类或者父类的限制,这在一定程度上符合里氏代换
缺点:
实例是父类的实例,不是子类的实例
不支持多继承
**组合继承:**通过调用父类构造,继承父类的属性并保留传参的优点,然后通过将父类实例作为子类原型,实现函数复用
注意:组合继承是需要修复构造函数指向的,否则部分版本会出问题
举个例子:

//组合继承function Cat(name){    Animal.call(this);    this.name = name || 'Tom';}Cat.prototype = new Animal();Cat.prototype.constructor = Cat;var cat = new Cat();document.writeln(cat.name+"
");cat.sleep();document.writeln("Is Animal:");document.writeln(cat instanceof Animal); // truedocument.writeln("
");document.writeln("Is Cat:");document.writeln(cat instanceof Cat); // falsedocument.writeln("
");

运行结果:

在这里插入图片描述
优点:可以给父类传参且函数可复用
缺点:调用了两次父类构造函数,生成了两份实例(子类实例将子类原型上的那份更改后覆盖了)
寄生组合继承:
通过寄生方式,搞掉父类的实例属性,这样,在调用两次父类的构造的时候,就不会初始化两次实例方法/属性,避免的组合继承的缺点
举个例子:

//寄生组合继承        function Cat(name){            Animal.call(this);            this.name = name || 'Tom';        }        (            function(){            // 创建一个没有实例方法的类            var Super = function(){};            Super.prototype = Animal.prototype;            //将实例作为子类的原型            Cat.prototype = new Super();            Cat.prototype.constructor = Cat;            }        )();        var cat =  new Cat();        document.writeln(cat.name+"
"); cat.sleep(); document.writeln("Is Animal:"); document.writeln(cat instanceof Animal); // true document.writeln("
"); document.writeln("Is Cat:"); document.writeln(cat instanceof Cat); // false document.writeln("
");

运行结果:

在这里插入图片描述

优点:解决了以上其他继承的缺点

缺点:子类的实现过程过于复杂
**多态:**就是在执行同一操作且作用于不同对象时,返回不同的结果 。
这个就是把Cat之类的换成Dog之类的类后执行不同的操作

转载地址:http://fqzj.baihongyu.com/

你可能感兴趣的文章
MySQL 高性能优化规范建议
查看>>
mysql 默认事务隔离级别下锁分析
查看>>
Mysql--逻辑架构
查看>>
MySql-2019-4-21-复习
查看>>
mysql-5.6.17-win32免安装版配置
查看>>
mysql-5.7.18安装
查看>>
MySQL-8.0.16 的安装与配置
查看>>
MySQL-Buffer的应用
查看>>
mysql-cluster 安装篇(1)---简介
查看>>
mysql-connector-java.jar乱码,最新版mysql-connector-java-8.0.15.jar,如何愉快的进行JDBC操作...
查看>>
mysql-connector-java各种版本下载地址
查看>>
mysql-EXPLAIN
查看>>
MySQL-Explain的详解
查看>>
mysql-group_concat
查看>>
MySQL-redo日志
查看>>
MySQL-【1】配置
查看>>
MySQL-【4】基本操作
查看>>
Mysql-丢失更新
查看>>
Mysql-事务阻塞
查看>>
Mysql-存储引擎
查看>>