`

frames["frameName"]用法bug?

 
阅读更多
闲话少说,直接上代码:
<body>
<iframe name="frameName" id="frameName" ></iframe>
<script type="text/javascript">
    var frameName22 = {a:1635879};
    var obj = frames["frameName"];
    for(var k in obj){
       alert(k+"========="+obj[k]);
    }
</script>
</body>

我们知道,frames["frameName"]是获取当前页面中name为frameName的框架的window对象。比如上例,obj即为一个iframe的window对象。

但是,如果此时当前页面中定义一个变量名也为frameName的一个变量或对象,例如:
<body>
<iframe name="frameName" id="frameName"></iframe>
<script type="text/javascript">
    var frameName = {a:1635879};
    var obj = frames["frameName"];
    for(var k in obj){
       alert(k+"========="+obj[k]);
    }
</script>
</body>

那么,此时obj即为你所定义的那个变量,即{a:1635879},与iframe没有任何关系。

你会对此发出疑问:产生这种结果是不是因为那个变量在后面,把前面的iframe覆盖掉了呢?针对你这种疑问,于是:
<body>
<script type="text/javascript">
    var frameName = {a:1635879};
    var ifrObj = document.createElement('iframe');
    ifrObj.name = "frameName";
    ifrObj.id = "frameName";

    document.body.appendChild(ifrObj);
    var obj = frames["frameName"];
    for(var k in obj){
       alert(k+"========="+obj[k]);
    }
</script>
</body>

运行结果显示:obj还是你所定义的那个变量,即{a:1635879}。从而可以有力的证明我们下面的猜想。

总结:对于frames["frameName"]返回的结果,按照以下原则:
如果页面中存在变量名为frameName的变量,那么frames["frameName"]会优先返回这个变量(可以这样理解:若window对象中存在属性名为frameName的属性,那么frames["frameName"]会优先返回这个属性所对应的值,相当于调用了window["frameName"]);如果没有这样的一个变量,才返回iframe所在的window的对象;如果此时也不存在这样的iframe,则最后返回undefined。

这是浏览器解析时的一个bug?还是故意这样设计的?
1
0
分享到:
评论
1 楼 wellrain 2012-10-17  
半年后,我再来看这篇文章;让我联想到了出自http://www.rainweb.cn/article/javascript-scope.html一篇关于js作用域的文章;我有点不清晰了:里面有这样一段分析:
var data = {name:'casper'};  
function data(){  
    alert('casper');  
}  
data();  //TypeError: object is not a function  

更正:在火狐浏览器中,结果是弹出 casper 的警告框!
而在chrome和IE9中,的确提示说data是一个对象,而不是一个函数
是不是有砸显示器的冲动。。。data此时其实为{name:'casper'},把一个object当函数调用,于是报错了
前面说过,函数声明(通过函数定义式)、var声明的变量会被提前,但是会有先后顺序之分,

function data(){  
    alert('casper');  
}  
var data;  
data = {name:'casper'};  
data();  

略微修改下,结果就不同鸟
var data = {name:'casper'};  
var data = function (){  //通过函数表达式声明函数  
    alert('casper');  
}  
data();  //结果:casper  
  
//结合上文不难猜想过程如下:  
  
var data;  
data = {name:'casper'};  
data = function (){  
    alert('casper');  
}  
data();  //结果:casper 

相关推荐

    document.frames在非IE浏览器中的解决办法

    针对`document.frames`在非IE浏览器中的兼容性问题,一个通用且被广泛采用的解决方案是使用`window.frames`。`window.frames`是所有现代浏览器都支持的标准API,它可以用来获取当前窗口中的所有iframe或frameset。 ...

    frames框架的应用[文].pdf

    可以使用`window.frames["frameName"].variable`或`window.frames["frameName"].function()`来访问和调用其他框架中的变量和函数。在编写JavaScript代码时,确保正确引用了目标框架并处理好作用域问题,是实现跨框架...

    Why Gabor Frames?

    这种方法通过优化阈值来提高重建信号的质量,可以与基础追求方法(Basis Pursuit)结合使用。 5. 高分辨率雷达成像:压缩感知技术结合多频率超窄带波形的Spotlight合成孔径雷达(SAR)成像具有明显的优势。它们不仅...

    matlab开发-apply2VideoFrames

    下面我们将深入探讨这个话题,包括MATLAB的视频处理基础、`apply2VideoFrames`函数的工作原理以及如何使用它来处理视频帧。 **MATLAB视频处理基础** MATLAB提供了强大的图像和视频处理工具箱,允许用户读取、处理和...

    js 操作 frameset frame iframe对象

    例如,从父框架引用子框架可以使用 `window.frames["frameName"]`,从子框架引用父框架可以使用 `window.parent`,兄弟框架之间的引用可以通过父框架来实现。 对框架的操作 JS 操作 Frameset、Frame、Iframe 对象...

    Python库 | audio.frames-2.3.1.tar.gz

    资源分类:Python库 所属语言:Python 资源全名:audio.frames-2.3.1.tar.gz 资源来源:官方 安装方法:https://lanzao.blog.csdn.net/article/details/101784059

    gif-frames:with使用纯JS从动画GIF中提取帧

    在引擎盖下使用和 。安装npm install gif-framesCDN脚本如果您不使用npm,则可以在HTML文件中包括以下之一: (未缩小) (最小) &lt;!-- unminified --&gt;&lt; script src =" ...

    An Introduction to Frames and Riesz Bases

    An Introduction to Frames and Riesz Bases pdf 版本

    Stack Frames A Look From Inside epub

    Stack Frames A Look From Inside 英文epub 本资源转载自网络,如有侵权,请联系上传者或csdn删除 本资源转载自网络,如有侵权,请联系上传者或csdn删除

    照片编辑器:Photo Editor Effects Frames2.4.0

    件名称:照片编辑器:Photo Editor Effects Frames 软件版本:v2.4.0内购解锁高级版 软件语言:英文/中文 软件大小:14.8M 软件包名:com.dhqsolutions.enjoyphoto 支持系统:Android 2.2+ 照片编辑器框架的影响...

    Finite frames

    压缩感知是一种能够在远低于奈奎斯特采样定理要求的采样率下,从信号中有效采样和重建信号的方法。它依赖于信号的稀疏性和冗余性,通过数学优化方法,可以从少量的测量值中重建出完整的信号。 综上所述,有限维框架...

    Protected Management Frames Interoperability Test Plan v1 4.pdf

    可选部分则允许设备制造商根据市场需求选择是否支持,如使用Station-to-Station (Sta-Sta) MFP或Station-to-Access Point (Sta-AP) MFP。 测试计划中包含的具体测试案例可能包括但不限于以下几点: 1. **认证过程...

    video_to_frames.rar_frames_video

    标题中的"video_to_frames.rar_frames_video"暗示了一个与视频处理相关的项目,主要涉及将视频转换为帧序列。这个过程在图像处理和计算机视觉领域中非常常见,因为视频本质上是由连续的图像帧组成的。Matlab是一种...

    matlab开发-frames2gif.zip.zip

    4. **使用方法**:在实际使用`frames2gif`函数时,你需要根据提供的文档或者源代码来了解如何调用它。一般会涉及提供帧的文件名或直接传入帧数据,以及设置相关参数。 5. **优化与效率**:由于处理大量图像可能会...

    wavelet frames and applications

    基于平衡方法和基于分析的方法是框架理论在图像处理中的重要应用。此外,框架理论还被用于盲去卷积、图像分割以及基于距离数据的场景重建。这些应用使得框架理论在图像处理领域具有很高的实用价值。 在图像处理中,...

    美国儿童数学思维启蒙工具系列二:十格阵(Ten Frames) - 简书1

    1. 可视化:Ten Frames 使用可视化的方式来呈现数学概念,使儿童更容易理解和记忆。 2. 互动性:Ten Frames 允许儿童通过填充格子和移动图形来进行互动,提高了儿童的参与度和兴趣。 3. 适应性:Ten Frames 可以根据...

    video2frames.m

    MATLAB读取视频文件,显示功能、保存成帧功能。MATLAB读取视频文件,显示功能、保存成帧功能。MATLAB读取视频文件,显示功能、保存成帧功能。

    Magic Bullet Frames 序列号

    序列号 Magic Bullet Frames

    matlab开发-frames2gif

    `license.txt`文件是许可协议,其中包含了使用`frames2gif`函数的条款和条件。通常,它会详细说明软件的版权信息、允许的用途、限制以及可能的商业使用规定。在使用该代码之前,你应该仔细阅读这个文件,确保你的...

Global site tag (gtag.js) - Google Analytics