javascript中的对象JS作为一种动态语言,在语法上有相当大的自由度,所以造成了一种功能,有N种写法的局面。
在JS中实现OOP,一般来说有两种方法:
第一种:使用this关键字
function Class1()
{
this.onclick = function(e)
{
for (var i=0; i < 1000; i++)
{
var a = new Date();
}
}
}
使用this.的方法可以很灵活地给对象添加属性和方法,而且和大部分的OOP语言都相似,甚至在运行中都可以添加。
第二种:使用prototype关键字
function clickFunc(e)
{
for (var i=0; i < 1000; i++)
{
var a = new Date();
}
}
function Class2()
{
}
Class2.prototype.onclick = clickFunc;
这种用法上来讲就没有第一种显得灵活。不过在一个对象new出来之前,也是一样可以随时添加一个对象的属性和方法。
可是他们并不是相等的,相对来说,我更喜欢第一种,因为第一种方法相对比较集中,比较容易阅读代码。但是在运行的时候,他们运行的效率却差别相当地大。以下让我们看一下测试代码吧:
var total = new Array();
function Test1()
{
var a = new Date();
for (var i=0; i < 10000; i++)
{
var c = new Class1();
//total.push(c);
}
var b = new Date();
alert(b.getTime()-a.getTime());
}
function Test2()
{
var a = new Date();
for (var i=0; i < 10000; i++)
{
var c = new Class2();
//total.push(c);
}
var b = new Date();
alert(b.getTime()-a.getTime());
}
第一步作执行时间的测试:发现Test1()需要142ms,而Test2()仅需50ms.发现时间效率上来说,prototype的方法相对this来说,更加高效。
javascript的对象第二步作内存占用的测试,把total.push(c);这行的注释去掉,之所以要把它们加入到数组里面去,防止创建的时候,对象比较多的时候,没有被引用的对象被GC了。结果发现差距不是一般的大,第一种方法要占用二三十M的内存,而第二种只需要一百多K。
javascript创建对象
成因推断:
在处理这两种代码的时候,第一种,JS的解析器,给每个对象都创建一个单独的方法,这样增加了内存的开销,同时创建方法的时候,增加了运行时间。第二种,JS的解析器和大部分的OOP编译器一样的,把对象的数据段和方法段分开存储了,对于对象的私有数据,则是每个对象一份,而这些方法,则是放在公共的方法段里,所以可以减少运行时间和内存的开销。
JavaScript面向对象的两种书写方法以及差别
2019-09-30 15:14建站经验网 ASP教程
一直以来看到好多高手都用js 对象实现代码的扩展,容易调用,思路明晰等特点,希望大家看完这篇文章后,可以继续看本站提供的几篇js面向对象的书写方法的文章.
延伸 · 阅读
- 2019-09-29wordpress中用JavaScript 输出页面代码的方法
- 2019-09-29WordPress的JavaScript 本地化实现
- 2019-09-27asp.net textbox javascript实现enter与ctrl+enter互换 文本
- 2019-09-27ASP javascript Application对象的Contents和StaticObjects做
- 2019-09-25使用JavaScript代码实现各种数据控件的反选功能
- 2019-09-25asp+javascript实现404页的处理转换
精彩推荐
- ASP教程
asp Response.flush 实时显示进度
如果你知道Response.Flush和Response.Clear,那你就可以不用这样的等待了。每生成一个Html页面,就用Response.write立即返回一条信息,提示该条数据库记录已经生成Html。 ...
- ASP教程
asp中获取内容中所有图片与获取内容中第一个图片的代码
用asp获取内容中的图片与获取内容中的第一个图片地址,主要是cms中保存内容中的图片需要用得到,使用的是正则的方法。...
- ASP教程
ASP基础入门第八篇(ASP内建对象Application和Session)
这篇文章主要介绍了ASP内建对象Application和Session的相关资料,需要的朋友可以参考下...
- ASP教程
ASP转换格林威治时间函数DateDiff()应用
ASP提供了一个叫 DateDiff() 的函数,这个函数可以返回一个时间差的秒,那就是说我们放进去一个格林威治标准时间与现在的时间对比一下返回秒就OK...
- ASP教程
ASP XML操作类代码
ASP XML操作类,想学习xml操作的朋友可以参考下。...
- ASP教程
ASP实现文件上传的方法
在基于浏览器/服务器的应用环境中,在浏览器中上传各种类型的文件一直是困扰用户文件管理应用的难题之一。常用的实现方法是利用在RFC1867中引入的一个新类型:File以及ADO Stream对象。本文对上述上传方法及实现原理作了论述,...
- ASP教程
对象不支持此属性或方法: Session.CodePage = 936 解决方法
这篇文章主要介绍了对象不支持此属性或方法: Session.CodePage = 936 解决方法,需要的朋友可以参考下...
- ASP教程
asp cint clng的范围与防止cint和clng的溢出解决方法大全
首先我们需要了解的是cint范围 -32,768 到 32,767。 clng范围 -2,147,483,648 到 2,147,483,647。 ...