Javascript window对象详解

 更新时间:2014年11月12日 17:16:14   投稿:hebedich  
本文详细介绍了JavaScript的window对象。Windows对象是一个顶层对象,而不是另一个对象的属性即浏览器的窗口。

首先看我们的源代码。

复制代码 代码如下:

<!DOCTYPE html> 
<html> 
    <head> 
        <meta charset="utf-8" /> 
        <title>深入理解Javascript</title> 
        <script type="text/javascript" charset="utf-8"> 
            console.log(this); 
        </script> 
    </head> 
    <body> 
        <h1>深入理解Javascript</h1> 
    </body> 
</html>

我们知道,通过浏览器打开这个页面,包含在<script> </script>标签中的 脚本会被执行,

那我们看一下 console.log(this); 这个this 到底指向的是谁呢?

在Google Chrome 中我们看到:

在Mozilla Firefox 中我们看到:

我们都看到输出的Window,那这个Window 与window是不是相等呢?

接着我们的测试

复制代码 代码如下:

<script type="text/javascript" charset="utf-8"> 
    console.log(this); 
    console.log('this == window ? ', this == window);  
</script> 

运行代码,输出this == window ?true ,这说明 Window== window,真的是这样吗?

为了搞清楚它们之间的关系,我们又接着测试

复制代码 代码如下:

<script type="text/javascript" charset="utf-8"> 
    console.log('this = ', this); 
    console.log('this == window ?', this == window); 
    console.log('window = ', window); 
    console.log('Window = ', Window) 
    console.log('Window == window ?', Window == window) 
</script>

看浏览器输出:

Google Chrome :


Mozilla Firefox :


从输出结果我们可以推出,

复制代码 代码如下:

this是指向Window对象;
this也等于window对象;
window也是指向Window对象;
Window是指向Window{},是浏览器提供的对象;
Window不等于window;

为什么会这样呢?

我们在浏览器控制台中查看Window对象的结构;


原来 Window对象包含的一些浏览器厂商实现的API,比如 html5中 的规范 sessionStorage;
它还有一个window的属性,这个属性的值就是指向Window对象;
我的理解:Window对象 是为浏览器厂商服务的,我们不能直接操作Window对象的属性,Window新增的API会反映到 window 对象中;
我们操作window 的属性 会反映到 Window 对象中。
比如 定义一个全局变量 window.a = 'aaa';

JavaScript的所有对象都存在于一个运行环境之中,这个运行环境本身也是对象,称为“顶层对象”。这就是说,JavaScript的所有对象,都是“顶层对象”的下属。不同的运行环境有不同的“顶层对象”,在浏览器环境中,这个顶层对象就是window对象。

所有浏览器环境的全局变量,都是window对象的属性。

可以把window理解成JavaScriptContext 上下文环境。

相关文章

  • Javascript 入门基础学习

    Javascript 入门基础学习

    习.net已经近2年了,最近学习Ajax时发现自己的很多技术功底很是欠缺,比如JavaScript。今后我会将我正在学习的也写成笔记,有时间的话将以前的东西整理整理也传上来。
    2010-03-03
  • JavaScript 事件绑定及深入

    JavaScript 事件绑定及深入

    这篇文章主要介绍了JavaScript 事件绑定及深入,需要的朋友可以参考下
    2015-04-04
  • ES6基础语法之对象介绍

    ES6基础语法之对象介绍

    这篇文章介绍了ES6中对象的用法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • JavaScript基本编码模式小结

    JavaScript基本编码模式小结

    本文中笔者整理的这些模式包含了编写JavaScript代码时一些常用的方法或者小技巧,可以帮助初学JavaScript的同学迅速提升代码质量
    2012-05-05
  • javascript基础知识整理

    javascript基础知识整理

    这篇文章对于刚开始学习js的朋友,非常有帮助,主要知识点都已经整理好了。
    2010-06-06
  • Javascript获取窗口(容器)的大小及位置参数列举及简要说明

    Javascript获取窗口(容器)的大小及位置参数列举及简要说明

    Javascript获取窗口(容器)的大小及位置一系列的东西比较多,容易混淆,在这里列举及简要说明下,需要的朋友可以参考下
    2012-12-12
  • 在javascript中创建对象的各种模式解析

    在javascript中创建对象的各种模式解析

    下面小编就为大家带来一篇在javascript中创建对象的各种模式解析。小编觉得挺不错的,现在分享给大家,也给大家做个参考,一起跟随小编过来看看吧
    2016-05-05
  • JavaScript 页面坐标相关知识整理

    JavaScript 页面坐标相关知识整理

    对于页面的一些坐标与位置分析,一般需要控制层的位置的朋友有帮助。需要的朋友可以参考下。
    2010-01-01
  • TypeScript中的装饰器用法

    TypeScript中的装饰器用法

    这篇文章介绍了TypeScript中装饰器的用法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06
  • 浅谈Web页面向后台提交数据的方式和选择

    浅谈Web页面向后台提交数据的方式和选择

    下面小编就为大家带来一篇浅谈Web页面向后台提交数据的方式和选择。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-09-09

最新评论