JavaScript简单和复杂型数据以及Web APIs

113 阅读3分钟

持续创作,加速成长!这是我参与「掘金日新计划 · 6 月更文挑战」的第28天

简单和复杂型数据

数据类型内存分配

数据类型的介绍

简单数据类型又叫做基本数据类型或者值类型,复杂数据类型又叫做引用类型

  • 值类型:简单数据类型/基本数据类型,在存储变量中存储的是值得本身,因此叫做值类型(string,number,boolean,undefined,null),简单数据类型null返回得是一个空对象object
var timer = null;
console.log(typeof timer); //object
//如果有个变量我们以后打算存储为对象,暂时没想好做什么,这个时候就给null
  • 引用类型:复杂数据类型,在存储时变量中存储得仅仅是地址(引用),因此叫做引用数据类型通过new关键字创建得对象(系统对象、自定义对象),如Object、Array、Date等

堆和栈

  1. 栈(操作系统):由操作系统自动分配释放存放函数得参数值、局部变量得值等。其操作方式类似于数据结构得栈;简单数据类型存放到栈里面
  2. 堆(操作系统):存储复杂类型(对象),一般由程序员分配释放,若程序员不释放,由垃圾回收机制回收。复杂数据类型存放到堆里

image-20220628093758915.png

注意:Javascript中没有堆栈得概念,通过堆栈得方式,可以让大家更容易理解代码得一些执行方式,便于将来学习其他得语言

内存分配

  1. 简单数据类型
  • 值类型(简单数据类型):string,number,boolean,undefined,null

  • 值类型变量的数据直接存放在变量(栈空间)中

  • image-20220628095541482.png

  1. 复杂数据类型
  • 引用类型(复杂数据类型):通过new关键字创建对象(系统对象、自定义对象),如Object、Array、Date等
  • 引用类型变量(栈空间)里面存放的是地址,真正的对象实例放在推空间中
  • image-20220628095449084.png

数据类型传参

  • 简单数据类型传参

简单数据类型的传参是直接把数据复制一份给参数,在方法内部对形参做任何修改都不会影响外部变量

  • 复杂数据类型传参

函数形参也可以看作是一个变量,当我们把引用类型变量传给形参时,其实就是把变量在栈空间里面保存的堆的地址复制给了形参,形参和实参其实保存的是同一个堆的地址,所以操作的是同一个对象

Web APIs

Web APIs和JS的关联

  • JS基础阶段

    • 学习了ECMAScript标准规定的基本语法
    • 学习基本语法实现不了常用的网页交互效果
  • Web APIs阶段

    • Web APIs是w3c组织的标准
    • Web APIs主要学习DOM和BOM
    • Web APIs是JS独有的部分
    • 主要学习页面交互功能

Web APIs是JS的应用

API和Web API

  • API

简单的理解就是API是一种程序员提供的一种工具,以便于能更轻松的实现想要完成的功能

  • Web API

Web API是浏览器提供的一套操作浏览器功能和页面元素的API(DOM和BOM)

  • 小结
  1. API是为我们程序员提供的一个接口,帮助我们实现某种功能,我们会使用就可以
  2. Web API主要针对于浏览器提供的接口,主要争对浏览器做交互效果
  3. Web API一般都有输入和输出(函数的传参和返回值),Web API很多都是方法(函数)