javascript面向对象学习之继承


继承

混入式继承

for in 使用for in遍历对象1的属性,将所有的属性添加到另外一个对象2上 这时候就可以称 对象2 继承自 对象1

原型继承

利用对象的动态特性,为原型对象添加成员

直接替换原型对象 1.替换前的对象,在替换之后,所有的成员都丢失 2.替换原型对象的时候,需要手动去指定原型对象的construtor属性

利用混入给原型对象添加成员

经典继承

var 对象1 = Object.create(对象2);

这个时候,创建出来的对象1继承自对象2

Object.create方法存在兼容性问题 如何解决? 1.检测浏览器是否支持Object.create方法,如果不支持,直接手动给Object添加create方法 2.自定义函数,在函数内部判断浏览器是否支持Object.create方法,如果不支持,则手动创建对象返回,否则直接调用

1
2
3
4
5
6
7
8
9
10
11
12
    function create(obj){ 
        if(Object.create){ 
            return Object.create(obj); 
        }else
            function F(){ 
            } 
 
            F.prototype = obj; 
 
            return new F(); 
        } 
    }

原型链

什么是原型链

每个构造函数都有原型对象,每个对象都有构造函数,每个构造函数的原型对象都是对象,也就有构造函数 然后就形成一个链式的结构,我们称之为原型链

原型继承是什么?

通过修改原型链的结构,实现继承的方式就是原型继承

对象和原型的成员关系

function Person(){}; 

var p = new Person();

p对象中包含的成员有:Person.prototype中的成员和自身拥有成员 Person.prototype中的成员有:Object.prototype的成员和自身的成员

p对象可以访问Person.prototype和Object.prototype中的所有成员

Object.prototype的成员

constructor :指向和该原型相关的构造函数

hasOwnProperty 方法: 判断对象本身是否拥有某个属性

properIsEnumerable 方法: 1.判断属性是否属于对象本身,2.判断属性是否可以被遍历

toString toLocaleString: 将对象转换成字符串 toLocalString转换成字符串的时候应用的本地的设置格式

valueOf 方法:在对象参与运算的时候,首先调用valueOf方法获取对象的值,如果该值无法参与运算,将会调用toString方法

proto 属性: 指向当前对象的原型对象

Function

3种创建函数的方式

直接声明函数

函数表达式

new Function()

可以用Function来创建函数: 语法:

var 函数名 = new Function();  //创建一个空的函数 

var 函数名 = new Function(“函数体”) //创建一个没有参数的函数 

var 函数名 = new Function(“参数1”,”参数2”, “参数3”,…”函数体”) 

//当给Fucntion传多个参数的时候,最后一个参数为函数体,前面的参数为创建出来的函数的形参 

//Function接收的所有的参数都是字符串类型的!!!

arguments对象

arguments对象是函数内部的一个对象,在函数调用的时候,系统会默认的将所有传入的实参存入该对象

注意:不管有没有形参,实参都会被存入该对象

eval

可以将字符串转换成js代码并执行

注意:当使用eval解析JSON格式字符串的时候,要注意,会将{}解析为代码段 1.可以在JSON格式字符串前面拼接 “var 变量名 =” eval(“var 变量名 =” + JSON格式的字符串);

2.可以在JSON格式字符串前后拼接() eval(“(“+JSON格式的字符串+”)”)

静态成员和实例成员

静态成员

通过构造函数去访问的属性和方法就是静态成员

实例成员

通过对象(实例)去访问的属性和方法就是实例成员