访问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/,如需转载请自行联系原博主。

目录
相关文章
|
19天前
|
设计模式 JavaScript 前端开发
js设计模式【详解】—— 构造函数模式
js设计模式【详解】—— 构造函数模式
21 6
|
17天前
|
存储 JavaScript 前端开发
|
18天前
|
前端开发 JavaScript
js 等待接口访问成功后执行指定代码【3种方法】(含async await Promise的使用)
js 等待接口访问成功后执行指定代码【3种方法】(含async await Promise的使用)
9 1
|
18天前
|
JavaScript 前端开发 网络架构
JavaScript编码之路【对象的增强、ES6新特性之函数的默认值设置 、rest参数 (剩余参数)、拓展运算符、对象与数组的解构赋值】
JavaScript编码之路【对象的增强、ES6新特性之函数的默认值设置 、rest参数 (剩余参数)、拓展运算符、对象与数组的解构赋值】
21 1
|
19天前
|
存储 JavaScript 前端开发
JavaScript 对象
JavaScript 对象
12 1
|
22天前
|
JavaScript Java 数据安全/隐私保护
js对象可扩展性和属性的四个特性(下)
js对象可扩展性和属性的四个特性(下)
|
15天前
|
前端开发 JavaScript Linux
若依修改之后,无法访问前端项目如何解决,只能访问后端的接口,我的接口8083,端不显示咋解决?在vue.config.js文件中的映射路径要跟后端匹配,到软件商店里找到Ngnix配置代理,设80不用加
若依修改之后,无法访问前端项目如何解决,只能访问后端的接口,我的接口8083,端不显示咋解决?在vue.config.js文件中的映射路径要跟后端匹配,到软件商店里找到Ngnix配置代理,设80不用加
|
16天前
|
JavaScript
js 简易对象转字符串后恢复为简易对象(如 ^a=$1^b=2转对象)
js 简易对象转字符串后恢复为简易对象(如 ^a=$1^b=2转对象)
13 0
|
17天前
|
JavaScript
js 数组移除指定元素【函数封装】(含对象数组移除指定元素)
js 数组移除指定元素【函数封装】(含对象数组移除指定元素)
13 0
|
17天前
|
JavaScript
JS 数组去重(含简单数组去重【5种方法】、对象数组去重【2种方法】)
JS 数组去重(含简单数组去重【5种方法】、对象数组去重【2种方法】)
15 0