访问JavaScript对象的构造函数时失败

简介:

 在JavaScript定义的对象中,不管是内部对象,还是用户自定的对象。如果该对象是从模态窗口(Modal Dialog)中创建并返回到主窗口中的,我们将无法在主窗口中取到该对象的构造函数(constructor)。

    执行如下两个示例:
    1、Main.htm

None.gif < html >
None.gif < head >
None.gif     < title >Main Page </ title >
None.gif     < meta  name ="author"  content ="birdshome@博客园"   />
None.gif </ head >
None.gif < body >
None.gif     < button  onclick ="GetValueFromDialog()" >
None.gif        click </ button >
ExpandedBlockStart.gif     < script >
InBlock.gif    
var  m_Array  =  []; 
InBlock.gif    
function  GetValueFromDialog()
ExpandedSubBlockStart.gif    
{
InBlock.gif         
var  array  =  window.showModalDialog('dialog.htm');
InBlock.gif         alert(array.constructor);
InBlock.gif         
//  alert(new m_Array.constructor);
InBlock.gif
          //  alert(new array.constructor);
ExpandedSubBlockEnd.gif
    }
ExpandedBlockEnd.gif   
</ script >
None.gif </ body >
None.gif </ html >
None.gif

    2、Dialog.htm
None.gif < html >
None.gif < head >
None.gif     < title >Modal Dialog </ title >
None.gif     < meta  name ="author"  content ="birdshome@博客园"   /> 
None.gif </ head >
None.gif < body >
ExpandedBlockStart.gif     < script >
InBlock.gif    
function  ReturnValue()
ExpandedSubBlockStart.gif    
{
InBlock.gif         window.returnValue 
=  ['modal dialog'];
InBlock.gif         
//  window.returnValue = new function foo(){}; 
InBlock.gif
         window.close();
ExpandedSubBlockEnd.gif    }
   
ExpandedBlockEnd.gif    
</ script >
None.gif    < button  onclick ="ReturnValue()" >close </ button > 
None.gif </ body >
None.gif </ html >
None.gif

    关闭弹出窗口dialog.htm,执行alert(array.constructor);将会引发脚本运行时异常:
None.gif A Runtime Error has occurred.
None.gif Do you wish to Debug?
None.gif
None.gif Line: 12
None.gif Error: Unexpected call to method or property access.
    // Unable to evaluate the expression. Catastrophic failure

    不过在这里JavaScript的内部对象和用户自定义对象还有一点小区别,如果是JS内部对象,我们访问对象的构造函数就立即出错。alert(array.constructor)就异常了。而如果是用户指定一对象,我们可以执行alert(array.constructor)得到一个显示"[object]"的MsgBox,但是这时的contrutor仍然不支持任何的操作和执行任何方法,比如new、.toString()等,一旦执行就出和上面一样的异常"Unable to evaluate the expression. Catastrophic failure"。

    这个缺陷似乎对我们的影响不是很大,不过对于一些依赖于对象的constructor来实现的功能就郁闷了,比如获取用户自定义对象的名称JavaScript面向对象编程之Singleton类、以及我上次做的一个对象Clone方法等,在这中情况下就都歇菜了hitwall.gif


本文转自博客园鸟食轩的博客,原文链接:http://www.cnblogs.com/birdshome/,如需转载请自行联系原博主。

目录
相关文章
|
14天前
|
JavaScript
JS 获取对象数据类型的键值对的键与值
JS 获取对象数据类型的键值对的键与值
|
23天前
|
JavaScript 前端开发
Math对象:JavaScript中的数学工具
Math对象:JavaScript中的数学工具
27 1
N..
|
1月前
|
存储 JavaScript 前端开发
JavaScript中的对象
JavaScript中的对象
N..
10 0
|
1月前
|
JavaScript
js开发:请解释什么是ES6的类(class),并说明它与传统构造函数的区别。
ES6的类提供了一种更简洁的面向对象编程方式,对比传统的构造函数,具有更好的可读性和可维护性。类使用`class`定义,`constructor`定义构造方法,`extends`实现继承,并可直接定义静态方法。示例展示了如何创建`Person`类、`Student`子类以及它们的方法调用。
22 2
|
1月前
|
JavaScript 前端开发
JavaScript对象系列(菜菜出品,必看!!!)
JavaScript对象系列(菜菜出品,必看!!!)
|
17天前
|
JavaScript 算法
原生JS完成“一对一、一对多”矩形DIV碰撞检测、碰撞检查,通过计算接触面积(重叠覆盖面积)大小来判断接触对象DOM
原生JS完成“一对一、一对多”矩形DIV碰撞检测、碰撞检查,通过计算接触面积(重叠覆盖面积)大小来判断接触对象DOM
|
1月前
|
存储 JavaScript 前端开发
在JavaScript中,对象和数组是如何进行扩展的?
在JavaScript中,对象和数组是如何进行扩展的?
22 4
|
1天前
|
存储 JavaScript 索引
js开发:请解释什么是ES6的Map和Set,以及它们与普通对象和数组的区别。
ES6引入了Map和Set数据结构。Map的键可以是任意类型且有序,与对象的字符串或符号键不同;Set存储唯一值,无重复。两者皆可迭代,支持for...of循环。Map有get、set、has、delete等方法,Set有add、delete、has方法。示例展示了Map和Set的基本操作。
11 3
|
3天前
|
JavaScript 前端开发 开发者
JavaScript中的错误处理:try-catch语句与错误对象
【4月更文挑战第22天】JavaScript中的错误处理通过try-catch语句和错误对象实现。try块包含可能抛出异常的代码,catch块捕获并处理错误,finally块则无论是否出错都会执行。错误对象提供关于错误的详细信息,如类型、消息和堆栈。常见的错误类型包括RangeError、ReferenceError等。最佳实践包括及时捕获错误、提供有用信息、不忽略错误、利用堆栈信息和避免在finally块中抛错。
|
8天前
|
JavaScript
【Js】检查Date对象是否为Invalid Date
【Js】检查Date对象是否为Invalid Date
10 0