js的构成

从来源来分类:

javascript 宿主分为:浏览器,nodejs(服务器端),weex/RN,Tessel(嵌入式)等
浏览器 nodejs
weex/RN

  1. 宿主对象(host object)
    由宿主提供的对象,在浏览器中window对象以及其下边所有的子对象(如bom、dom等等),在node中是globla及其子对象,也包含自定义的类对象。

  2. 非宿主对象

    • 原声对象(也叫内部对象、本地对象、native object )
      独立于宿主环境的ECMAScript实现提供的对象。与宿主无关,在javascript(远景浏览器)、nodejs(node平台)、jscript(ie浏览器)、typescript(微软平台)等等中均有这些对象。简单来说,本地对象就是 ECMA-262 定义的类(引用类型)。在运行过程中动态创建的对象,需要new。如:
      Object、Function、Array、String、Boolean、Number、Date、RegExp、Error、EvalError、RangeError、ReferenceError、SyntaxError、TypeError、URIError、Global

    • 内置对象
      由 ECMAScript 实现提供的、独立于宿主环境的所有对象,在 ECMAScript 程序开始执行时出现,即在引擎初始化阶段就被创建好的对象。这意味着开发者不必明确实例化内置对象,它已被实例化了。如:
      Global(全局对象)、Math

tips:

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

  • 拓展方法内容
    无论是什么对象,均可以通过prototype进行功能拓展。

  • 打印浏览器的全局对象
    打印自定义的对象,会显示出源码,但是打印全局对象,因为这些全局对象是程序自带的,是二进制编译的,所以无法显示出来源代码,它就只能给你‘native code’
    这里写图片描述

浏览器中js的构成

这里写图片描述

  1. ECMAScript(非宿主,核心)

    1. 本地对象
      Object、Function、Array、String、Boolean、Number、Date、RegExp、Error、EvalError、RangeError、ReferenceError、SyntaxError、TypeError、URIError、Global
    2. 内置对象
      Math 和 Global
      Global:14个顶层函数(全局函数)
      6个和编码相关

      decodeURI() 解码某个编码的 URI。
      decodeURIComponent()    解码一个编码的 URI 组件。
      encodeURI() 把字符串编码为 URI。
      encodeURIComponent()    把字符串编码为 URI 组件。
      escape()
      unescape()
      2个判断
      
      isFinite()  检查某个值是否为有穷大的数。
      isNaN() 检查某个值是否是数字。
      4个转换
      
      2个对象
      Number()    把对象的值转换为数字。
      String() 把对象的值转换为字符串。
      2个字符串
      parseFloat()    解析一个字符串并返回一个浮点数。
      parseInt()  解析一个字符串并返回一个整数。
      2个
      
      eval()  计算 JavaScript 字符串,并把它作为脚本代码来执行。
      getClass()  返回一个 JavaObject 的 JavaClass

      这里写图片描述

  2. DOM(宿主)

    1. DOM API
      1. DOM Document
      2. DOM Element
      3. DOM Attribute
      4. DOM Event
  3. BOM(宿主)
    1. Window
    2. Navigator
    3. Screen
    4. Histroy
    5. Location
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值