js高级---本地对象、内置对象、宿主对象

 

名词参考:
原生对象:也叫内部对象、本地对象、native object
内置对象:Build-in object
宿主对象:host objectjavascript


ECMA-262 定义
原生对象:独立于宿主环境的ECMAScript实现提供的对象。与宿主无关,在javascript(远景浏览器)、nodejs(node平台)、jscript(ie浏览器)、typescript(微软平台)等等中均有这些对象。简单来讲,本地对象就是 ECMA-262 定义的类(引用类型)。在运行过程当中动态建立的对象,须要new
内置对象:由 ECMAScript 实现提供的、独立于宿主环境的全部对象,在 ECMAScript 程序开始执行时出现,即在引擎初始化阶段就被建立好的对象。这意味着开发者没必要明确实例化内置对象,它已被实例化了
宿主对象:即由 ECMAScript 实现的宿主环境提供的对象,包含两大类,一个是宿主提供,一个是自定义类对象,ECMAScript官方未定义的对象都属于宿主对象,全部非本地对象都是宿主对象。宿主提供对象原理--->由宿主框架经过某种机制注册到ECscript引擎中的对象,如宿主浏览器(以远景为参考)会向ECscript注入window对象,构建其实现javascript。。java


内容
原生对象:Object、Function、Array、String、Boolean、Number、Date、RegExp、Error、EvalError、RangeError、ReferenceError、SyntaxError、TypeError、URIError、Global
内置对象:Global(全局对象)、Math
宿主对象:有宿主提供的对象,在浏览器中window对象以及其下边全部的子对象(如bom、dom等等),在node中是globla及其子对象,也包含自定义的类对象。【何为“宿主对象”?  在web中,ECMAScript中的“宿主”固然就是咱们网页的运行环境,即“操做系统”和“浏览器”。全部非本地对象都是宿主对象(host object),即由 ECMAScript 实现的宿主环境提供的对象。】
全局对象:通常全局对象会有两个,一个是ecma提供的Global对象,一个是宿主提供。如在浏览器中是window、在nodejs中是global。【因此啊,在浏览器中全局对象是Global+window】
一般状况下ecma提供的Global对象对是不存在的,没有具体的对象,

查看window下,当前全部的成员,除了console.log(window),你还能够这么作
在chrome进行debug时候中有个scope,当前做用域,其中Global只显示了window全部的成员,并无显示Ecma的Global,由于我没有找到Ecma提供的Global任何字段和函数
node

 

 

 

 

 

它们之间的关系
本地对象与内置对象:原生包含内置,内置是原生的一个子集。
宿主对象:内置对象的Global和宿主提供的一个全局对象,web

本地对象为array obj regexp等能够new实例化
内置对象为gload Math 等不能够实例化的
宿主为宿主注入到全局的对象,如浏览器的window 等chrome


特别说明:
内置对象之Global
Global即为全局对象,Global对象是ECMAScript中最特别的对象,由于实际上它根本不存在!
在ECMAScript中,不存在独立的函数,全部函数都必须是某个对象的方法。
相似于isNaN()、parseInt()和parseFloat()方法等,看起来都是函数,而实际上,它们都是Global对象的方法。
并且Global对象的方法还不止这些。具体参考http://www.w3school.com.cn/jsref/jsref_obj_global.asptypescript

 

拓展方法内容
不管是什么对象,都可以经过prototype进行功能拓展。

打印浏览器的全局对象
打印自定义的对象,会显示出源码,可是打印全局对象,由于这些全局对象是程序自带的,是二进制编译的,因此没法显示出来源代码
它就只能给你‘native code’浏览器

<script>
    var myfc=function(){var a=123;}
    console.log(myfc)//浏览器全局对象之window下自定义的myfc函数
    console.log(alert)//浏览器全局对象之window的alert函数
    console.log(isNaN)//浏览器全局对象之Global的isNaN函数
</script>

 

 

相关
http://blog.csdn.net/zihuanzq_2014/article/details/52006504
http://www.jb51.net/article/85831.htm
http://lzw.me/pages/ecmascript/
http://yanhaijing.com/es5/#4
框架

相关文章
相关标签/搜索