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

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

高老师9年前 (2017-10-07)H53390
//原型的缺点
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停止定时器,	js删除定时器

javascript停止定时器, js删除定时器

    window.setInterval(method,time)方法本身会返回一个资源句柄,使用clearInterval(Intervalid)方法即可清除定时器<script> var num=0; //每隔1秒再控制台输...

Javascript事件冒泡和捕捉的阻止

Javascript事件冒泡和捕捉的阻止

<!DOCTYPE html> <html> <head> <title>捕捉和冒泡</title> <meta charset="utf-8"> </head> <bo...

Js显示本周星期对应的日期,非固定,周一,周三,周六

Js显示本周星期对应的日期,非固定,周一,周三,周六

开发需求如下,商品下单后需要指定送到日期:送达日期为周一 周三  周六 ,如果今天周一,用户选择周一即为下一周周一。代码如下:<html> <head> <meta charset="utf-8"> <title>...

ajax上传文件,formdata上传文件,ajax上传file文件,原生ajax上传文件,ajax上传图片,ajax上传文件formdata

ajax上传文件,formdata上传文件,ajax上传file文件,原生ajax上传文件,ajax上传图片,ajax上传文件formdata

通过FormData对象可以组装一组用 XMLHttpRequest发送请求的键/值对。它可以更灵活方便的发送表单数据,因为可以独立于表单使用。如果你把表单的编码类型设置为multipart/form-data ,则通过FormData传输的数据格式和表单通过submit() 方法传输的数据格式相同...

js cookie操作,js获取cookie值的方法,js 设置cookie

js cookie操作,js获取cookie值的方法,js 设置cookie

维护老项目中客户提到一个页面中有6个表单以上,导致每次保存一个其他的数据全部丢失,自己比较懒没有全部更换为ajax.用户每次输入完成或者选择完成记录cookie,每次提交后加载页面完成初始化cookie即可。以下代码取自w3school比较完善,之前在其他博客使用的经常出现bug,这个比较推荐使用:...

 js图片旋转插件jqueryrotate

js图片旋转插件jqueryrotate

jQuery 插件——jqueryrotate,它可以实现旋转效果。jqueryrotate 支持所有主流浏览器,包括 IE6。如果提示方法不存在,可能是你的Jquery版本过低或者过高。基本语法:$('#img').rotate(90);//旋转90度其他的参数:参数类型说明默认值...