当前位置:首页 > H5 > 正文内容

js原型对象的缺点,js原型链及其优缺点

高老师7年前 (2017-10-07)H53138
//原型的缺点
function Box(){}
Box.prototype={
	'name':'gao',
	 age:23,
	 family:['哥哥','姐姐','妹妹'],
	 run:function(){
		return this.name+'--'+this.age;
	 } 
}

//1.缺少构造函数来初始化参数
var  box1=new Box();
var  box2=new Box();

box1.age=12;
//2.原型中存在引用类型,多个实例会共享.例如1个追加数组元素,其他实例同时被追加
box1.family.push('弟弟');
console.log(box1.family);
console.log(box2.family);
console.log(box2.age);


//3.解决以上2个问题

//不需要共享的使用构造方法
function  BBox(name,age){
	this.name=name;
	this.age=age;
	this.family=['1','2','3'];
}
//需要共享的地方使用原型
BBox.prototype={
	constructor:BBox,
	run:function(){
		return this.name+'--'+this.age+'--'+this.family;
	}
}
var bbox1=new BBox('gao',23);
console.log(bbox1.run());

//4.由于在原型中,不管你是否调用了共享方法,它都会初始化一遍,于是我们可以简化如下.简称动态原型模式

function  BBBox(name,age){
	this.name=name;
	this.age=age;
	this.family=['1','2','3'];
	//原型只需要执行1次,立即共享
	if(typeof this.run !='function'){
		BBBox.prototype.run=function(){
			return this.name+'--'+this.age+'--'+this.family;			
		}	
	}
}

var  BBBox1=new BBBox('chen',24);
console.log(BBBox1.run());

扫描二维码推送至手机访问。

版权声明:本文由高久峰个人博客发布,如需转载请注明出处。

本文链接:https://blog.20230611.cn/post/262.html

分享给朋友:

“js原型对象的缺点,js原型链及其优缺点” 的相关文章

Javascript封装的原生Ajax请求

Javascript封装的原生Ajax请求

由于工作需要长期使用Ajax,一个页面重复的AJAX请求太多,于是封装起来,只需要编写回调函数/* ------------- 使用方法: 1.ajaxrequest()函数执行准备的参数(1.请求地址2.发送数据字符串拼接3.type值可选get/post4.回调函数名称)   exam...

Javascript事件冒泡和捕捉

Javascript事件冒泡和捕捉

捕捉模式从DOM最顶层一直到最后一层,冒泡正好相反,具体运行以下实例测试.<!DOCTYPE html> <html> <head> <title>捕捉和冒泡</title> <meta charset="...

tmodjs模板语法

tmodjs模板语法

    TmodJS是一套完整的前端模块框架。    虽然我们PHP框架自带各种模板引擎,但是始终是后端模板引擎。例如我们在使用ThinkPHP3.2.3中如果是Ajax异步加载页面,拼接HTML真的是很头疼的一件事情。...

Javascript绑定事件和移除事件

Javascript绑定事件和移除事件

<!DOCTYPE html> <html> <head> <title></title> <meta charset="utf-8"> </head> <body>...

使用js让手机震动,js实现手机震动

使用js让手机震动,js实现手机震动

<!doctype html> <html> <head> <meta charset="utf-8"> <title>无标题文档</title> </head>  ...

Javascript获取Mac地址

Javascript获取Mac地址

<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>获取mac地址</title> </head&g...