在Javascript中构建一个类有好几种方法:
1.Factory 方式
function createCar(){
var car=new Object();
car.color=”b”;
car.length=1;
car.run=function(){alert(”run”);}
return car;
}
定义这么一个函数之后,就可以用:
var car1=createCar();
var car2=createCar();
来创建新的对象,这种方式的问题是每一次创建一个car对象,run Function也都必须
重新创建一次.浪费内存
2.Constructor方式
function Car(){
this.color=”b”;
this.length=1;
this.run=function(){alert(”run”);}
}
var car1=new Car();
var car2=new Car();
这是最基本的方式,但是也存在和factory方式一样的毛病
3.prototype方式
function Car(){
}
Car.prototype.color=”b”;
Car.prototype.length=1;
Car.prototype.run=function(){alert(”run”);}
这个方式的缺点是,当这个类有一个引用属性时,改变一个对象的这个属性也会改变其他对象得属性
比如:
Car.prototype.data1=new Array();
var car1=new Car();
var car2=new Car();
car1.data1.push(”a”);
此时,car2.data也就包含了”a”元素
4.Prototype/Constructor杂合方式
function Car(){
this.color=”b”;
this.length=1;
this.data1=new Array();
}
Car.prototype.run=function(){
alert(”dddd”);
}
这种方式去除了那些缺点.是目前比较大范围使用的方式
5.动态prototype方式
function Car(){
this.color=”b”;
this.length=1;
this.data1=new Array();
if(typeof Car.initilize==”undefined”){
Car.prototype.run=function(){alert(”a”);}
}
Car.initilize=true;
}
这几种方式中,最常用的是杂合prototype/constructor 和 动态prototype方式
分享到:
相关推荐
JavaScript类在Web开发中的应用广泛,它们允许我们创建复杂的数据结构,封装逻辑,以及实现面向对象的编程风格。在ASP.NET中,我们可以通过以下几种方式使用JavaScript类: 1. **定义和实例化JavaScript对象**:在...
JavaScript 类
JavaScript 类是编程语言中用于构建面向对象模型的关键概念,它允许我们通过类来模拟现实世界中的对象和...了解和熟练掌握JavaScript类的概念和用法,对于进行软件开发和程序设计至关重要,尤其是在构建复杂应用时。
JavaScript 类是编程语言中用于构建面向对象模型的关键概念,它允许开发者通过类来组织和抽象数据及行为。本文将从基础出发,逐步深入地讲解...理解和掌握JavaScript类的概念,对于编写可维护和可扩展的代码至关重要。
在这个系列的第一部分,我们将深入探讨JavaScript类模板的基础知识,以及如何使用它们来创建和实例化对象。 首先,我们需要了解在ES5之前的JavaScript中,我们通常使用构造函数和原型链来实现面向对象的特性。但...
因此,理解函数和原型是理解JavaScript类的基础。 1. **函数与构造函数** 在JavaScript中,函数可以作为一等公民,这意味着函数可以赋值给变量、作为参数传递或作为其他函数的返回值。当我们使用`new`关键字调用一...
JavaScript 类 1
【温故而知新】JavaScript类、类继承、静态方法
EventBus, 用于管理事件的简单JavaScript类 简单的JavaScript类,用于管理JavaScript中的事件安装浏览器中的下载 eventbus.min.js 插件并将它的添加到你的页面。节点中的npm i eventbusjs -S然后在你的代码中:
javascript并发任务Javascript 类,允许注册多个回调以同时执行(排序)以执行单个函数。 例子: var syncFuncs = new SyncFuncs ( ) ;syncFuncs . registerTask ( function ( ) { $ . ajax ( { url : '...
实用javascript类 表单ajax提交
el.js, 本机javascript类和创建dom对象的方法 el.js用于创建元素的简单Javascript库,不需要其他库示例:元素的创建创建一个没有属性的简单元素el('div')=> <div></div>一些vanity方
这篇文章是关于 JavaScript 的,所以我们先来了解一下 JavaScript 是一种怎样的语言。到目前为止,JavaScript 是一种不完全支持面向对象特性的脚本语言。之所以这样说是因为 JavaScript 的确支持对象的概念,...
尽管没有具体的代码,但可以想象它可能包含了一个使用上述类方式实现的JavaScript类。通过分析这个文件,我们可以学习到实际编程中类的运用,以及如何将理论知识应用到实践中。 总结起来,JavaScript的类方式多种...
通过这样的通用JavaScript类,开发者可以创建出更健壮、可维护的ASP.NET应用,同时提高开发效率。不过,随着技术的发展,现代Web开发中更多地倾向于使用库和框架(如jQuery、React、Vue等),它们提供了更高级别的...
JavaScript类提供了`public`(默认)、`private`和`protected`三种访问控制符,但需要注意的是,JavaScript的私有属性和方法实际上是通过闭包实现的,而不是像其他一些语言那样在语法层面上支持。 7. **类表达式**...
在本话题中,我们将深入探讨JavaScript中的类继承,并特别关注`this.callParent`这个方法,它是如何被用来调用超类方法的。 首先,让我们了解JavaScript中的构造函数。构造函数是一种特殊的函数,用于创建和初始化...
继承是面向对象开发的又一个重要概念,它可以将现实生活的概念对应到程序逻辑中。...在JavaScript中没有专门的机制来实现类的继承,但可以通过拷贝一个类的prototype到另外一个类来实现继承等扥,看资料