分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 前端开发

经典面试题:js继承方式下

发布时间:2023-09-06 01:18责任编辑:白小东关键词:js面试题

上一篇讲解了构造函数的继承方式,今天来讲非构造函数的继承模式。

一、object()方法

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

function object(o) {     ???function F() {}     ???F.prototype = o;     ???return new F();  }

二、浅拷贝

除了使用"prototype链"以外,还有另一种思路:把父对象的属性,全部拷贝给子对象,也能实现继承。

下面这个函数,就是在做拷贝:

function extendCopy(p) {     ???var c = {};     ???for(var i in p) {       ???????c[i] = p[i];     ???}     ???c.uber = p;     ???return c;  }

三、深拷贝

所谓"深拷贝",就是能够实现真正意义上的数组和对象的拷贝。它的实现并不难,只要递归调用"浅拷贝"就行了。

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;  }

目前,jQuery库使用的就是这种继承方法。

经典面试题:js继承方式下

原文地址:http://www.cnblogs.com/zt123123/p/7676662.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved