博客
关于我
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 order by多个字段排序
查看>>
MySQL Order By实现原理分析和Filesort优化
查看>>
mysql problems
查看>>
mysql replace first,MySQL中处理各种重复的一些方法
查看>>
MySQL replace函数替换字符串语句的用法(mysql字符串替换)
查看>>
mysql replace用法
查看>>
Mysql Row_Format 参数讲解
查看>>
mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
查看>>
MySQL Server 5.5安装记录
查看>>
mysql server has gone away
查看>>
mysql slave 停了_slave 停止。求解决方法
查看>>
MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
查看>>
MYSQL sql语句针对数据记录时间范围查询的效率对比
查看>>
mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
查看>>
mysql Timestamp时间隔了8小时
查看>>
Mysql tinyint(1)与tinyint(4)的区别
查看>>
mysql union orderby 无效
查看>>
mysql v$session_Oracle 进程查看v$session
查看>>
mysql where中如何判断不为空
查看>>
MySQL Workbench 使用手册:从入门到精通
查看>>