面向对象(三)——非构造函数继承

1.使用object方法

json格式的发明人Douglas Crockford,提出了一个object()函数,可以做到这一点

var parentFn = {
    name: "小明"
}
function object(p){
    function c(){}
    c.prototype = p;
    return new c();
}
var children = object(parentFn);
children.age = "18"
console.log(children.name) // 小明

2.浅拷贝

var parentFn = {
    name: "小明"
}
function extendCopy(p){
    var c = {};
    for(var i in p){
        c[i] = p[i];
    }
    c.uber = p;
    return c;
}
var children = extendCopy(parentFn);
children.age = "16";
console.log(children.name) // 小明

但是这种方法有个问题,就是不能复制数组和对象

var parentFn = {
    name: "小明"
}
function extendCopy(p){
    var c = {};
    for(var i in p){
        c[i] = p[i];
    }
    c.uber = p;
    return c;
}
parentFn.city = ["北京","上海"];
var children = extendCopy(parentFn);
children.city.push("深圳");
console.log(children.city) // ["北京","上海","深圳"]
console.log(parentFn.city) // ["北京","上海","深圳"]

这样会使得父级的数组也改变,所以该方法并不能复制数组和对象

3.深拷贝

该方法是jquery中使用的复制属性方法

var parentFn = {
    name: "小明"
}
var children = {
    age: "16"
}
function deepCopy(p, c) {
    var c = c || {};
    for (var i in p) {
        if (typeof p[i] === 'object') {
            c[i] = (p[i].constructor === Array) ? [] : {};
            deepCopy(p[i], c[i]);
        } else {
            c[i] = p[i];
        }
    }
    return c;
}
parentFn.city = ["北京","上海"];
var children = deepCopy(parentFn,children);
children.city.push("深圳")
console.log(parentFn) // ["北京","上海"]
console.log(children) // ["北京","上海","深圳"]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值