分享
 
 
 

&#106avascript面向对象的支持(5)

王朝html/css/js·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

======================================================================

Qomolangma OpenProject v0.9

类别 :Rich Web Client

关键词 :JS OOP,JS Framwork, Rich Web Client,RIA,Web Component,

DOM,DTHML,CSS,JavaScript,JScript

项目发起:aimingoo (aim@263.net)

项目团队:aimingoo, leon(pfzhou@gmail.com)

有贡献者:JingYu(zjy@cnpack.org)

=====================================================================

八、JavaScript面向对象的支持

~~~~~~~~~~~~~~~~~~

(续)

4). 需要用户维护的另一个属性:constructor

------

回顾前面的内容,我们提到过:

- (如果正常地实现继承模型,)对象实例的constructor属性指向构造器

- obj.constructor.prototype指向该对象的原型

- 通过Object.constructor属性,可以检测obj2与obj1是否是相同类型的实例

与原型链要通过用户代码来维护prototype属性一样,实例的构造器属性constructor

也需要用户代码维护。

对于JavaScript的内置对象来说,constructor属性指向内置的构造器函数。如:

//---------------------------------------------------------

// 内置对象实例的constructor属性

//---------------------------------------------------------

var _object_types = {

'function' : Function,

'boolean' : Boolean,

'regexp' : RegExp,

// 'math' : Math,

// 'debug' : Debug,

// 'image' : Image;

// 'undef' : undefined,

// 'dom' : undefined,

// 'activex' : undefined,

'vbarray' : VBArray,

'array' : Array,

'string' : String,

'date' : Date,

'error' : Error,

'enumerator': Enumerator,

'number' : Number,

'object' : Object

}

function objectTypes(obj) {

if (typeof obj !== 'object') return typeof obj;

if (obj === null) return 'null';

for (var i in _object_types) {

if (obj.constructor===_object_types[i]) return i;

}

return 'unknow';

}

// 测试数据和相关代码

function MyObject() {

}

function MyObject2() {

}

MyObject2.prototype = new MyObject();

window.execScript(''+

'Function CreateVBArray()' +

' Dim a(2, 2)' +

' CreateVBArray = a' +

'End Function', 'VBScript');

document.writeln('<div id=dom style="display:none">dom<', '/div>');

// 测试代码

var ax = new ActiveXObject("Microsoft.XMLHTTP");

var dom = document.getElementById('dom');

var vba = new VBArray(CreateVBArray());

var obj = new MyObject();

var obj2 = new MyObject2();

document.writeln(objectTypes(vba), '<br>');

document.writeln(objectTypes(ax), '<br>');

document.writeln(objectTypes(obj), '<br>');

document.writeln(objectTypes(obj2), '<br>');

document.writeln(objectTypes(dom), '<br>');

在这个例子中,我们发现constructor属性被实现得并不完整。对于DOM对象、ActiveX对象

来说这个属性都没有正确的返回。

确切的说,DOM(包括Image)对象与ActiveX对象都不是标准JavaScript的对象体系中的,

因此它们也可能会具有自己的constructor属性,并有着与JavaScript不同的解释。因此,

JavaScript中不维护它们的constructor属性,是具有一定的合理性的。

另外的一些单体对象(而非构造器),也不具有constructor属性,例如“Math”和“Debug”、

“Global”和“RegExp对象”。他们是JavaScript内部构造的,不应该公开构造的细节。

我们也发现实例obj的constructor指向function MyObject()。这说明JavaScript维护了对

象的constructor属性。——这与一些人想象的不一样。

然而再接下来,我们发现MyObject2()的实例obj2的constructor仍然指向function MyObject()。

尽管这很说不通,然而现实的确如此。——这到底是为什么呢?

事实上,仅下面的代码:

--------

function MyObject2() {

}

obj2 = new MyObject2();

document.writeln(MyObject2.prototype.constructor === MyObject2);

--------

构造的obj2.constructor将正确的指向function MyObject2()。事实上,我们也会注意到这

种情况下,MyObject2的原型属性的constructor也正确的指向该函数。然而,由于JavaScript

要求指定prototype对象来构造原型链:

--------

function MyObject2() {

}

MyObject2.prototype = new MyObject();

obj2 = new MyObject2();

--------

这时,再访问obj2,将会得到新的原型(也就是MyObject2.prototype)的constructor属性。

因此,一切很明了:原型的属性影响到构造过程对对象的constructor的初始设定。

作为一种补充的解决问题的手段,JavaScript开发规范中说“need to remember to reset

the constructor property',要求用户自行设定该属性。

所以你会看到更规范的JavaScript代码要求这样书写:

//---------------------------------------------------------

// 维护constructor属性的规范代码

//---------------------------------------------------------

function MyObject2() {

}

MyObject2.prototype = new MyObject();

MyObject2.prototype.constructor = MyObject2;

obj2 = new MyObject2();

更外一种解决问题的方法,是在function MyObject()中去重置该值。当然,这样会使

得执行效率稍低一点点:

//---------------------------------------------------------

// 维护constructor属性的第二种方式

//---------------------------------------------------------

function MyObject2() {

this.constructor = arguments.callee;

// or, this.constructor = MyObject2;

// ...

}

MyObject2.prototype = new MyObject();

obj2 = new MyObject2();

5). 析构问题

------

JavaScript中没有析构函数,但却有“对象析构”的问题。也就是说,尽管我们不

知道一个对象什么时候会被析构,也不能截获它的析构过程并处理一些事务。然而,

在一些不多见的时候,我们会遇到“要求一个对象立即析构”的问题。

问题大多数的时候出现在对ActiveX Object的处理上。因为我们可能在JavaScript

里创建了一个ActiveX Object,在做完一些处理之后,我们又需要再创建一个。而

如果原来的对象供应者(Server)不允许创建多个实例,那么我们就需要在JavaScript

中确保先前的实例是已经被释放过了。接下来,即使Server允许创建多个实例,而

在多个实例间允许共享数据(例如OS的授权,或者资源、文件的锁),那么我们在新

实例中的操作就可能会出问题。

可能还是有人不明白我们在说什么,那么我就举一个例子:如果创建一个Excel对象,

打开文件A,然后我们save它,然后关闭这个实例。然后我们再创建Excel对象并打开

同一文件。——注意这时JavaScript可能还没有来得及析构前一个对象。——这时我们

再想Save这个文件,就发现失败了。下面的代码示例这种情况:

//---------------------------------------------------------

// JavaScript中的析构问题(ActiveX Object示例)

//---------------------------------------------------------

<script>

var strSaveLocation = 'file:///E:/1.xls'

function createXLS() {

var excel = new ActiveXObject("Excel.Application");

var wk = excel.Workbooks.Add();

wk.SaveAs(strSaveLocation);

wk.Saved = true;

excel.Quit();

}

function writeXLS() {

var excel = new ActiveXObject("Excel.Application");

var wk = excel.Workbooks.Open(strSaveLocation);

var sheet = wk.Worksheets(1);

sheet.Cells(1, 1).Value = '测试字符串';

wk.SaveAs(strSaveLocation);

wk.Saved = true;

excel.Quit();

}

</script>

<body>

<button onclick="createXLS()">创建</button>

<button onclick="writeXLS()">重写</button>

</body>

在这个例子中,在本地文件操作时并不会出现异常。——最多只是有一些内存垃

圾而已。然而,如果strSaveLocation是一个远程的URL,这时本地将会保存一个

文件存取权限的凭证,而且同时只能一个(远程的)实例来开启该excel文档并存

储。于是如果反复点击"重写"按钮,就会出现异常。

——注意,这是在SPS中操作共享文件时的一个实例的简化代码。因此,它并非

“学术的”无聊讨论,而且工程中的实际问题。

解决这个问题的方法很复杂。它涉及到两个问题:

- 本地凭证的释放

- ActiveX Object实例的释放

下面我们先从JavaScript

[1] [2] 下一页

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有